题意:在[l, r]中找到3n+1猜想最大步数的数字


解题思路: 在[l, r]中枚举每个数字,每次枚举完都更新最大值

注意事项: 给出的两个数字大的在前小的在后时,交换一下便于处理

参考代码:

#include <bits/stdc++.h>
using namespace std;

int main() {
	int l, r;
	while (scanf("%d%d", &l, &r) != EOF) {
		printf("%d %d ", l, r); //先输出 
		if (l > r) swap(l, r); //需要交换就交换一下,确保小数在前 
		
		int mlen = 0, tlen = 0; //最大步数,当前步数 
		for (int i = l, temp = l; i <= r; i++, temp = i) { //枚举区间中的每个数字 
			tlen = 1;
			while (temp != 1) { //3n+1猜想 
				if (temp % 2) temp = temp * 3 + 1;
				else temp /= 2;
				tlen++;
			}
			mlen = max(mlen, tlen); //保留最大值 
		}
		printf("%d\n", mlen);
		
	}
	return 0;
}


点赞(0)
 

0.0分

3 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 2 条评论

渴望学到知识的菜鸟 3年前 回复TA
绝了,这才是大佬
东东东 3年前 回复TA