【PAT】1005. 继续(3n+1)猜想 (25)
1005. 继续(3n+1)猜想 (25)
卡拉兹(Callatz)猜想已经在1001中给出了描述。在这个题目里,情况稍微有些复杂。
当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数。例如对n=3进行验证的时候,我们需要计算3、5、8、4、2、1,则当我们对n=5、8、4、2进行验证的时候,就可以直接判定卡拉兹猜想的真伪,而不需要重复计算,因为这4个数已经在验证3的时候遇到过了,我们称5、8、4、2是被3“覆盖”的数。我们称一个数列中的某个数n为“关键数”,如果n不能被数列中的其他数字所覆盖。
现在给定一系列待验证的数字,我们只需要验证其中的几个关键数,就可以不必再重复验证余下的数字。你的任务就是找出这些关键数字,并按从大到小的顺序输出它们。
输入格式:每个测试输入包含1个测试用例,第1行给出一个正整数K(<100),第2行给出K个互不相同的待验证的正整数n(1<n<=100)的值,数字间用空格隔开。
输出格式:每个测试用例的输出占一行,按从大到小的顺序输出关键数字。数字间用1个空格隔开,但一行中最后一个数字后没有空格。
输入样例:
6
3 5 6 7 8 11
输出样例:
7 6 设计思路:
1.构造一个num[100]数组,将每个元素初始化为0,将输入的k个数值temp作为num[]的下标,并使对应的数组值为1.比如输入的数值为11,则num[11]=1;数组下标即即为输入的值;
2.找到num[]中元素为1对应的所有的下标值(即输入的值),进行(3n+1)猜想,并将每次新产生的需要进行验证的数作为数组的下标,使对应的元素值为-1;
比如对3进行验证,下一个需要验证的值为5,则num[5]=-1;
3.此时数组中元素仍为1的对应的下标值即为需要求出的“关键数”。 C++ 代码如下:
#include<bits/stdc++.h>
using namespace std;
int num[]={};
int main(){
int k,i,temp,flag=;
cin>>k;
for(i=;i<k;i++){
cin>>temp;
num[temp]=;
}
for(i=;i<;i++){
if(num[i]==){
temp=i;
while(temp!=){
if(temp%==) temp=temp/;
else temp=(*temp+)/;
if(temp<) num[temp]=-;
}
}
}
for(i=;i>=;i--){ //从大到小输出
if(num[i]==){
if(flag==){
cout<<i;
flag=; //第一次输出无空格
}
else cout<<' '<<i;
}
}
system("pause");
return ;
}
【PAT】1005. 继续(3n+1)猜想 (25)的更多相关文章
- PAT 1005 继续(3n+1)猜想 (25)(代码)
		
1005 继续(3n+1)猜想 (25)(25 分) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下 ...
 - PAT 1005. 继续(3n+1)猜想 (25) JAVA
		
当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候,我们需要计算3.5.8.4.2.1,则当我们对n=5.8.4.2进行验证的时候,就可以直接 ...
 - PAT 1005. 继续(3n+1)猜想 (25)
		
卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候, ...
 - PAT——1005. 继续(3n+1)猜想 (25)
		
卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候, ...
 - PAT 乙级 1005. 继续(3n+1)猜想 (25)
		
1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情 ...
 - PAT乙级   1005. 继续(3n+1)猜想 (25)
		
1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz ...
 - [C++]PAT乙级1005. 继续(3n+1)猜想 (25/25)
		
/* 1005. 继续(3n+1)猜想 (25) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推 ...
 - PAT 乙级 1005 继续(3n+1)猜想 (25) C++版
		
1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz ...
 - PAT-B 1005. 继续(3n+1)猜想 (25) c++
		
1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz ...
 
随机推荐
- windows下php扩展存在但无法加载的问题
			
1.可能存在多个php环境,扩展没有放对地方 2.扩展和php版本不对应,例如,php是32位,扩展是64位:或者php是nts版本,但是扩展不是nts版本.
 - Xshell连接Linux服务器总掉线
			
Xshell连接linux服务器总掉线,解决办法如下: 1.登录服务器后 [root@test134 ~]# cd /etc/ssh/ [root@test134 ssh]# vim sshd_con ...
 - go defer注意点,很容易出错的!!!
			
1:defer是在return之前执行的 函数返回的过程是这样的:先给返回值赋值,然后调用defer表达式,最后才是返回到调用函数中 返回值 = xxx 调用defer函数 空的return fun ...
 - Tensorboard教程:显示计算图中节点信息
			
Tensorboard显示计算图节点信息 觉得有用的话,欢迎一起讨论相互学习~Follow Me 参考文献 强烈推荐Tensorflow实战Google深度学习框架 实验平台: Tensorflow1 ...
 - Java设计模式の责任链模式
			
在阎宏博士的<JAVA与模式>一书中开头是这样描述责任链(Chain of Responsibility)模式的: 责任链模式是一种对象的行为模式.在责任链模式里,很多对象由每一个对象对其 ...
 - CF766 ABCDE
			
LINK A 找最长非公共子序列..如果两串不是完全相同 显然就是最长的那个 /** @Date : 2017-04-15 19:52:34 * @FileName: 766A.cpp * @Plat ...
 - 重构改善既有代码设计--重构手法10:Move Method (搬移函数)
			
你的程序中,有个函数与其所驻类之外的另一个类进行更多的交流:调用后者,或被后者调用.在该函数最常用引用的类中建立一个有着类似行为的新函数.将旧函数编程一个单纯的委托函数,或是将旧函数完全移除. 动机: ...
 - C语言与汇编语言对照分析
			
游戏通常会包含各种各样的功能,如战斗系统.UI渲染.经济系统.生产系统等,每个系统又包含各式各样子功能,如伤害判定.施法.使用道具.角色移动.玩家之间交易等等.这些游戏功能在代码实现中往往少不了条件判 ...
 - 23、Xpath
			
1.什么是Xpath?1.XPath即为XMLPath的简称,它是一种用来确定XML文档中某部分位置的语言.2.HTML可以看做是XML的一种实现,所以selenium用户可以使用这种强大的语言在we ...
 - Thinkphp的SQL查询方式
			
一.普通查询方式 a.字符串$arr=$m->where("sex=0 and username='gege'")->find();b.数组$data['sex']=0 ...