杭电1032题

2024-08-28 07:58
文章标签 杭电 1032

本文主要是介绍杭电1032题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

3n+1问题
Problem Description
Problems in Computer Science are often classified as belonging to a certain class of problems (e.g., NP, Unsolvable, Recursive). In this problem you will be analyzing a property of an algorithm whose classification is not known for all possible inputs.

Consider the following algorithm:


    1.      input n

    2.      print n

    3.      if n = 1 then STOP

    4.           if n is odd then n <- 3n + 1

    5.           else n <- n / 2

    6.      GOTO 2


Given the input 22, the following sequence of numbers will be printed 22 11 34 17 52 26 13 40 20 10 5 16 8 4 2 1

It is conjectured that the algorithm above will terminate (when a 1 is printed) for any integral input value. Despite the simplicity of the algorithm, it is unknown whether this conjecture is true. It has been verified, however, for all integers n such that 0 < n < 1,000,000 (and, in fact, for many more numbers than this.)

Given an input n, it is possible to determine the number of numbers printed (including the 1). For a given n this is called the cycle-length of n. In the example above, the cycle length of 22 is 16.

For any two numbers i and j you are to determine the maximum cycle length over all numbers between i and j.

Input
The input will consist of a series of pairs of integers i and j, one pair of integers per line. All integers will be less than 1,000,000 and greater than 0.

You should process all pairs of integers and for each pair determine the maximum cycle length over all integers between and including i and j.

You can assume that no opperation overflows a 32-bit integer.

Output
For each pair of input integers i and j you should output i, j, and the maximum cycle length for integers between and including i and j. These three numbers should be separated by at least one space with all three numbers on one line and with one line of output for each line of input. The integers i and j must appear in the output in the same order in which they appeared in the input and should be followed by the maximum cycle length (on the same line).

Sample Input
    
1 10 100 200 201 210 900 1000

Sample Output
    
1 10 20 100 200 125 201 210 89 900 1000 174

Source
UVA  
代码。
#include<iostream>
using namespace std;
int countt(int n)
{   int count=1;
while(n>1)
{if(n%2==0) n/=2;
 else 
n=n*3+1;
count++;
}
return count;
}
int main()
{
int i,j,a,max,t;
while(cin>>i>>j)
{   bool mark=false;
if(i<=0||i>=1000000)break;
if(j<=0||j>=1000000)break;
if(j<i){t=i;i=j;j=t;mark=1;}
max=countt(i);
for(int k=i+1;k<=j;k++)
{  a=countt(k);
if(a>max)max=a;
}
if(mark)cout<<j<<" "<<i<<" "<<max<<endl;
if(!mark)cout<<i<<" "<<j<<" "<<max<<endl;
}
return 0;
}
summary:这道题不难但却耗费我挺长时间。其实不能说题不好只是自己应该变得更仔细。题中并没有说i一定小于j !!!这是这道题的关键。还有这道题变量用int 信就行。题中有说明.

这篇关于杭电1032题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1114182

相关文章

2024杭电8

1004.cats 的重力拼图 题意: 有一个n*m的矩阵,给出最开始拼图的位置。 可以有四个选择,设置重力的方向,就是拼图会向一个方向竖直掉落到最底。 问任意操作次数后拼图走过的方格数量最大值。 题解: 首先已经在边缘的拼图,只能沿着边走一圈,再判断最开始可以朝哪个方向移动是最大值。 代码: #include<bits/stdc++.h>using namespace s

2024杭电6

1001.造花(简单版) 题意: 菊花图:n-1个节点都连接同一节点的树。 给定一棵树,删掉一个节点和连向这个点的所有边,使剩下两个连通块都构成菊花图,问是否可以做到。 题解: 菊花图只有中心节点的度可以没有限制,其余节点的度都是1。 要删除一个节点,要求剩下两个连通块,那就只能删掉度为2的节点,剩下两个菊花图,菊花图最多一个度不是1的节点。 所以度不是1的节点数最多为5,如图。

杭电 1297 Children’s Queue .

http://acm.hdu.edu.cn/showproblem.php?pid=1297   计算F(n): 一:当最后一个是男孩M时候,前面n-1个随便排出来,只要符合规则就可以,即是F(n-1); 二:当最后一个是女孩F时候,第n-1个肯定是女孩F,这时候又有两种情况:         1)前面n-2个可以按n-2个的时候的规则来,完全可以,即是F(n-2);

2014.1.13 杭电习题 绝对值排序

绝对值排序 Problem Description(问题描述) 输入n(n<=100)个整数,按照绝对值从大到小排序后输出。题目保证对于每一个测试实例,所有的数的绝对值都不相等。 Input(输入) 输入数据有多组,每组占一行,每行的第一个数字为n,接着是n个整数,n=0表示输入数据的结束,不做处理。 Output(输出) 对于每个测试实例,输出排序后的结果,两个数之间用一个

2014.1.13 杭电习题 二维字符串中出现数量最多的字符串

Let the Balloon Rise Time Limit : 2000/1000ms (Java/Other)   Memory Limit : 65536/32768K (Java/Other) Total Submission(s) : 15   Accepted Submission(s) : 6 Font: Times New Roman | Verdana | Georgi

递推—杭电2044 一只小蜜蜂...

http://acm.hdu.edu.cn/showproblem.php?pid=2044 一只小蜜蜂... Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 35811    Accepted Submission(s): 1317

杭电1280 前m大的数(哈希表)

前m大的数 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 9557    Accepted Submission(s): 3350 Problem Description 还记得Gardon给小希布置的那个作业么?(上次比赛的1

杭电1867 A + B for you again

Hot~ 2014暑期多校联合训练——正式启动报名~ 详见“杭电ACM”微博~ A + B for you againTime Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 3811    Accepted Submission(s):

杭电2087 剪花布条

跟1711一样的kmp入门题目 #include<stdio.h> #include<string.h> char s[1111],t[1111]; int next[1111],len1,len2; void getnext() { int i=1,j=0; next[1]=0; while(i<len2) { if(j==0||t[i]==t[j])

杭电1060

不知道公式,修改了别人的代码,公式应该是a=n*lgn;然后10^(a的小数)取整型; #include #include int main() {     __int64 k,b,i,d;     double a,m,n,c;     scanf("%I64d",&k);     while(k--)     {         scanf("%lf",&n);         a=n*