【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,n109

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,我们可以列表解决这个问题(见下图)
cmd-markdown-logo
我们发现,只需要做到小数+大数,依次相加,可以保证数的大小,再定义一个变量记录最小步数就行了。也就是如下代码:

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;
}

听完后,是不是觉得很简单呢?赶快自己去试一下吧!!!

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值