P a r t Part Part 1 1 1 读题
题目描述
w g y wgy wgy发明了 J X JX JX编程语言,在这种编程语言里,只有 + = += +=这个运算符,可以将某个变量的值增加。
现在输入 a a a, b b b, n n n,请问仅使用 a a a, b b b两个变量来进行 + = += +=运算,最少多少次能够严格超过 n n n的值。
只能使用 a + = b a+=b a+=b,或者 b + = a b+=a b+=a,不能使用 a + = a a+=a a+=a或 b + = b b+=b b+=b。
输入格式
三个整数 a a a, b b b, n n n(三个数都不超过 1 0 9 10^9 109)
输出格式
一个整数,代表最少步数
输入样例1
1 2 3
输出样例1
2
输入样例2
5 12 14
输出样例2
3
数据范围与提示
对于 100 % 100\% 100%的数据, a , b , n ≤ 1 0 9 a,b,n≤10^9 a,b,n≤109
P a r t Part Part 2 2 2 思路
本题算是作者在暑假期间写的最简单的题了,实际上本题也就一个难点,我们举例看看:
假设
a
=
1
a=1
a=1,
b
=
2
b=2
b=2,
n
=
30
n=30
n=30,我们可以列表解决这个问题(见下图)
我们发现,只需要做到小数+大数,依次相加,可以保证数的大小,再定义一个变量记录最小步数就行了。也就是如下代码:
while(a<=n&&b<=n){//保证两数都不大于n
//判断a、b的大小,进行计算
if(a<b)a+=b;
else b+=a;
s++;//最小步数的记录
}
然后我们再加上定义、输入和输出就可以啦!
小tip:大家可以先根据思路,写一下代码哦!
P a r t Part Part 3 3 3 代码
#include<bits/stdc++.h>
using namespace std;
int a,b,n,s;
int main(){
cin>>a>>b>>n;
while(a<=n&&b<=n){
if(a<b)a+=b;
else b+=a;
s++;
}
cout<<s;
return 0;
}
听完后,是不是觉得很简单呢?赶快自己去试一下吧!!!