[题]P1150 Peter 的烟 #数学推导

题目

P1150 Peter 的烟

题解

为什么要记录这个入门题呢

因为一个题解:博客跳转

我自己做的是模拟整个吸烟然后烟蒂换烟的过程,很笨。

这个数学推导真的震撼我

最后一个式子就搞定:n+(n-1)/(k-1)

基于该题解的我的分析过程:

n个烟蒂可以换一根烟,这根烟吸完可以获得一个烟蒂

那么在烟蒂足够的情况下,每n-1个烟蒂就是一根烟

数学式表示为:n烟蒂 = 1烟 + 1烟蒂 => n-1烟蒂 = 1烟

但是这个代换有一个前提:你必须在一开始就有n个烟蒂

所以,重申一遍:烟蒂满足n个的情况下,每n-1个烟蒂就是一根烟

比如我每6个烟蒂才能换一根烟时,按照上面的推导我可以5个烟蒂换一根烟

但是我最后剩下的5个烟蒂还能这样换吗?显然不能。

所以我们一开始就将烟蒂总数减去1,使得最后的n-1个烟蒂变为n-2个

这个操作对前面的烟蒂是不会有影响的,前面的烟蒂会正常地被换掉

这样最后要是剩下n-1个烟蒂就不会进行交换

代码

我按照模拟吸烟的思路写的,能过。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int main(){
	int n, k, sum;
	cin >> n >> k;
	sum = n;//原有的肯定会吸完 
	while(n >= k){//n此时代表的是烟蒂的数量
		int y = n / k;//换来y根烟 
		n %= k;//还剩下n个烟蒂 
		sum += y;
		n += y;//y根烟吸完后又来y个烟蒂 
	}
	cout << sum;
	return 0; 
}
相关推荐
大白话_NOI25 分钟前
【洛谷 P1303】A*B Problem + 详细分析
c++
小欣加油32 分钟前
leetcode2161 根据给定数字划分数组
数据结构·c++·算法·leetcode·职场和发展
吃着火锅x唱着歌1 小时前
深度探索C++对象模型 学习笔记 第五章 构造、解构、拷贝语意学(2)
c++·笔记·学习
玖釉-1 小时前
Vulkan 离屏渲染详解:从 Framebuffer 到后处理、阴影贴图与 Render Texture
c++·windows·计算机视觉·图形渲染
cpp_25011 小时前
P2947 [USACO09MAR] Look Up S
数据结构·c++·算法·题解·单调栈·洛谷
楼田莉子1 小时前
C++20新特性:协程
开发语言·c++·后端·学习·c++20
炘爚1 小时前
phase1:基础框架——编译 + MySQL + 登录/注册
linux·c++
特种加菲猫2 小时前
C++11核心特性深度解析:从列表初始化到lambda与包装器
开发语言·c++
枕星而眠2 小时前
C++ 面向对象核心机制深度解析:多态性、虚函数、虚继承与 final 类
运维·开发语言·c++·后端
智者知已应修善业2 小时前
【51单片机8个LED,已经使用了D1D2,怎么样在不动D1D2的前提下实现D6~D8的流水灯】2024-1-19
c++·经验分享·笔记·算法·51单片机