100 - The 3n+1 problem (3n+1 问题)

/*
* 100 - The 3n+1 problem (3n+1 问题)
* 作者 仪冰
* QQ 974817955
*
* [问题描述]
* 考虑如下的序列生成算法:从整数 n 开始,如果 n 是偶数,把它除以 2;如果 n 是奇数,
* 把它乘 3 加1。用新得到的值重复上述步骤,直到 n = 1 时停止。
* 例如,n = 22 时该算法生成的序列是:
* 22,11,34,17,52,26,13,40,20,10,5,16,8,4,2,1
* 人们猜想(没有得到证明)对于任意整数 n,该算法总能终止于 n = 1。
* 这个猜想对于至少 1 000 000 内的整数都是正确的。
* 对于给定的 n,该序列的元素(包括 1)个数被称为 n 的循环节长度。
* 在上述例子中,22 的循环节长度为 16。
* 输入两个数 i 和 j,你的任务是计算 i 到 j(包含 i 和 j)之间的整数中,
* 循环节长度的最大值。 * [输入]
* 输入每行包含两个整数 i 和 j。所有整数大于 0,小于 1 000 000。
*
* [输出]
* 对于每对整数 i 和 j,按原来的顺序输出 i 和 j,然后输出二者之间的整数中的最大循环节长度。
* 这三个整数应该用单个空格隔开,且在同一行输出。
* 对于读入的每一组数据,在输出中应位于单独的一行。
*
[样例输入]
1 10
100 200
201 210
900 1000 [样例输出]
1 10 20
100 200 125
201 200 27
900 1000 174 * [解题方法]
* 计算每个数的循环节长度,求给定区间的最大值。
*
* 需要注意:
* 1.中间计算过程有的数据会超出int 或 long 型范围,应该用long long型。
* 2.输入的两个数,应该比较大小,判断出左区间和右区间。
* 3.直接按部就班的计算会time limited(超时),这里采用填表的方法,
* 把算出来的结果保存在一个全局数组中,这样以后用到的时候,直接拿来用,节省时间,避免超时。
*/ #include<iostream>
#include<cstring> using namespace std; const int MAXN = 1000000; //右端点最大值 int MediaVariableArray[MAXN]; //保存区间中所有的循环节长度,这是对填表的应用 int LoopNodeLength (long long EveryNumber); //计算循环节长度 int main()
{
int firstnumber = 0; //输入的第一个数
int secondnumber = 0; //输入的第二个数
int nodeleft = 0; //区间左端点
int noderight = 0; //区间右端点
int loopnodemax = 0; //保存最大长度的循环节
int everynodelength = 0; //保存区间中单个数的循环节长度 memset(MediaVariableArray, 0, sizeof(MediaVariableArray)); //初始化,都置为0 while (cin >> firstnumber >> secondnumber)
{
if (firstnumber > secondnumber) //判断左端点和右端点
{
nodeleft = secondnumber;
noderight = firstnumber;
}
else
{
nodeleft = firstnumber;
noderight = secondnumber;
} loopnodemax = 0; //初始化最大值
for (int i=nodeleft; i<=noderight; i++)
{
everynodelength = LoopNodeLength(i); if (everynodelength > loopnodemax) //判断是否更新最大值
{
loopnodemax = everynodelength;
}
} cout << firstnumber << " " <<secondnumber << " ";
cout << loopnodemax << endl;
} return 0;
} int LoopNodeLength(long long EveryNumber)
{
if (EveryNumber == 1)
{
return 1;
} if (EveryNumber & 1) //按位与1 等价于 对2求模;左移 等价于 乘以2,同理右移是除以2。
{
//计算n = 3n + 1;
//左移运算符比加号优先级低,所以加括号;
//我建议不管怎样,为了代码易读都应该加上必要的括号。
EveryNumber = EveryNumber + (EveryNumber<<1) + 1;
}
else
{
EveryNumber >>= 1; //n = n / 2
} //如果中间计算值小于MAXN就看看我们先前求没求出它的循环节长度,
//如果求出来了,直接拿来用,节省时间。
if (EveryNumber < MAXN)
{
if (MediaVariableArray[EveryNumber] == 0)
{
MediaVariableArray[EveryNumber] = LoopNodeLength(EveryNumber);
} return MediaVariableArray[EveryNumber] + 1;
} return LoopNodeLength(EveryNumber) + 1;
}

UVA 100 - The 3n+1 problem (3n+1 问题)的更多相关文章

  1. UVa 100 - The 3n + 1 problem(函数循环长度)

    题目来源:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=3&pa ...

  2. 【转】UVa Problem 100 The 3n+1 problem (3n+1 问题)——(离线计算)

    // The 3n+1 problem (3n+1 问题) // PC/UVa IDs: 110101/100, Popularity: A, Success rate: low Level: 1 / ...

  3. PC/UVa 题号: 110101/100 The 3n+1 problem (3n+1 问题)

     The 3n + 1 problem  Background Problems in Computer Science are often classified as belonging to a ...

  4. 100-The 3n + 1 problem

    本文档下载 题目: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_pro ...

  5. OpenJudge/Poj 1207 The 3n + 1 problem

    1.链接地址: http://bailian.openjudge.cn/practice/1207/ http://poj.org/problem?id=1207 2.题目: 总时间限制: 1000m ...

  6. The 3n + 1 problem

    The 3n + 1 problem Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) ...

  7. poj1207 3n+1 problem

    The 3n + 1 problem Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 60496   Accepted: 19 ...

  8. 杭电OJ——1032 The 3n + 1 problem

    The 3n + 1 problem Problem Description Problems in Computer Science are often classified as belongin ...

  9. HDU 1032 The 3n + 1 problem (这个题必须写博客)

    The 3n + 1 problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Other ...

随机推荐

  1. pyqt说明

    我是个PHP程序员,不过有时候觉得需要写些小软件,对于我这种不太熟悉桌面软件开发的人来说,界面问题最让我头痛.听说Qt很强大,而且是跨平台,所以决定学习它用来弥补我写桌面软件的不足. Qt一般是通过C ...

  2. web前端之 JS

    JavaScript概述 JavaScript是一门编程语言,简称js,由浏览器编译并运行,JS说白了就是让页面能够动起来 js存在形式 1.在html页面中 <script> alert ...

  3. boost::asio译文

        Christopher Kohlhoff Copyright © 2003-2012 Christopher M. Kohlhoff 以Boost1.0的软件授权进行发布(见附带的LICENS ...

  4. linux 常用 命令 笔记二

    wget 下载,得到网络上的内容 grep 文件搜索工具 EveryThing is a file in the linux system 安装 cowsay sudo apt-get install ...

  5. [跟我学Spring学习笔记][DI配置与使用]

    DI 依赖和依赖注入 定义 传统的依赖一般指"类之间的关系",那先让我们复习一下类之间的关系: 泛化:表示类与类之间的继承关系.接口与接口之间的继承关系: 实现:表示类对接口的实现 ...

  6. [core java学习笔记][第十一章异常断言日志调试]

    第11章 异常,断言,日志,调试 处理错误 捕获异常 使用异常机制的技巧 使用断言 日志 测试技巧 GUI程序排错技巧 使用调试器 11.1 处理错误 11.1.1异常分类 都继承自Throwable ...

  7. .NET批量大数据插入性能分析及比较

    数据插入使用了以下几种方式 1. 逐条数据插入2. 拼接sql语句批量插入3. 拼接sql语句并使用Transaction4. 拼接sql语句并使用SqlTransaction5. 使用DataAda ...

  8. 前端--关于css选择器

    css选择器就好像表达式一样,返回一组或者一个html元素,后面的样式声明块应用到返回的元素上.所以可以把css选择器理解为某个或者某一类html元素的抽象的写法. 在讲具体的各种选择器之前要提一下选 ...

  9. CSS减肥的工具–Firefox插件 CSS Usage

    首先,我们需要安装Firefox(猛击此处下载),或者确定你已经安装的版本已经高于3.1; 第二步,安装前端开发人员最普及的开发工具 Firebug: 第三步,安装CSS Usage 0.3.4.1: ...

  10. jquery简单切换插件

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...