本文主要是介绍【C++题解】[2020普及组模拟题]wgy的JX语言,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
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;
}
听完后,是不是觉得很简单呢?赶快自己去试一下吧!!!
这篇关于【C++题解】[2020普及组模拟题]wgy的JX语言的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!