PAT1005 继续(3n+1)猜想
卡拉兹(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 (<),第 2 行给出 K 个互不相同的待验证的正整数 n (1)的值,数字间用空格隔开。
输出格式:
每个测试用例的输出占一行,按从大到小的顺序输出关键数字。数字间用 1 个空格隔开,但一行中最后一个数字后没有空格。
输入样例:
6
3 5 6 7 8 11
输出样例:
7 6
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.CompilerServices;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading.Tasks; namespace ConsoleApp5
{
class Program
{
static int Main(string[] args)
{
//输入数列的长度
int number = Convert.ToInt32(Console.ReadLine());
//列表用来存放最后筛选出来的关键数,方便进行排序
List<int> li = new List<int>();
//用来存储输入的数列的各个数
string[] befnum = new String[number];
//用来存放一个数的卡拉兹数列
int[] solvenum = new int[];
//用来存放关键数,由上述列表转化而来
int[] keynum = new int[number];
int j = ;
int copy = ;
int m = ;
int n = ;
//定义一个二位数组,第一个维度表示数列中的对应数字,第二个维度做为标识符
int[,] record = new int[number, ];
//输入的数列
string info = Console.ReadLine();
//输入的数列按空格分割成各个数
befnum = info.Split(' ');
//初始化record数组
for (int i = ; i < number; i++)
{
record[i, ] = ;
}
//记录数列中每个数的卡拉兹数列
for (int i = ; i < number; i++)
{
copy = Convert.ToInt32(befnum[i]);
j = ;
while (copy != )
{
if (copy % == )
{
solvenum[j] = copy;
copy = copy / ;
j++;
}
else
{
solvenum[j] = copy;
copy = ( * copy + ) / ;
j++;
}
}
//当前数列
for (int l = ; l < number; l++)
{
n = ;
//猜想中的数字
//将当前数列中的每一个数和每个数的猜想数列的各个数比较
for (int k = ; k < j; k++)
{
//如果比较的数是自身就跳过,因为卡拉兹数列的第一个数是他本身
if (Convert.ToInt32(befnum[l]) == solvenum[k])
{
break;
}
else
{
//非自身的数但是被覆盖,卡拉兹数列有数和他相同,结束循环
if (Convert.ToInt32(befnum[l]) == solvenum[k])
{
break;
}
}
//一轮比较下来,既不是自身又没被覆盖则记录符号+1
n++;
//j为卡拉兹数列的长度,一轮下来这个数和卡拉兹数列中的每个数都不相同
if (n == j)
{
//二维标识符++
record[l, ]++;
} }
} }
for (int k = ; k < number; k++)
{
//排除自身当这个数和输入数列中每个数的卡拉兹数列中的各个数都不相同即标识符等于输入数列长度-1
if (record[k, ] == number - )
{
//往列表中加入关键数
li.Add(Convert.ToInt32(befnum[k]));
m++;
}
}
//对列表进行排序
li.Sort();
keynum = li.ToArray();
for (int i = ; i < m - ; i++)
{
Console.Write(keynum[i]);
Console.Write(" ");
}
//最后一个数不带空格
Console.WriteLine(keynum[m - ]);
return ;
}
}
}
这是第一次做的思路,做复杂了,答案输出没有问题但是在PAT官网提交出现了问题求大神help

之后换了一种思路
using System;
using System.Collections;
using System.Collections.Generic;
using System.Linq;
using System.Runtime.CompilerServices;
using System.Text;
using System.Text.RegularExpressions;
using System.Threading;
using System.Threading.Tasks; namespace ConsoleApp5
{
class Program
{
static int Main(string[] args)
{
int type = ;
int copy = ;
int t = ;
//输入数列的长度
int count = Convert.ToInt32(Console.ReadLine());
//输入数列
string info = Console.ReadLine();
//存储后续关键数
int[] answer = new int[count];
int[] key = new int[];
//根据空格分割数列
string[] number = info.Split(' ');
//存放输入数列中的各个数
int[] realnum = new int[count];
//初始化key数组
for (int i = ; i < ; i++)
{
key[i] = ;
}
//将字符串数组转换为整形数组
for (int i = ; i < count; i++)
{
realnum[i] = Convert.ToInt32(number[i]);
}
//冒泡排序,这部我之前没想到,先排序再处理,筛选后的数还是在原来排序基础上的
for (int i = ; i < count - ; i++)
{
for (int j = ; j < count - - i; j++)
{
if (realnum[j] > realnum[j + ])
{
type = realnum[j];
realnum[j] = realnum[j + ];
realnum[j + ] = type;
}
}
}
//检查key,将输入数列中的各个数的卡拉兹数列中的各个数用key数组标识,用卡拉兹数列中的数做为下标,并把以这个下标的key数组中的数置为1
for (int i = ; i < count; i++)
{
copy = realnum[i];
while (copy != )
{
if (copy % == )
{
copy = copy / ;
}
else
{
copy = ( * copy + ) / ;
}
key[copy] = ;
} }
//这个思路是将输入数列中的数和卡拉兹数列中各个数实现一个映射关系,通过key数组这个中介
//判断key数组中以输入数列中的数做为下标的数是否为1,若为1表示被覆盖,为2则表示是关键数
for (int i = ; i < count; i++)
{
if (key[realnum[i]] == )
{
//存入answer数组中
answer[t] = realnum[i];
t++;
} }
//将关键数输出,每个数之间有个空格最后一个数不带空格
int k = ;
for (k = ; k < t - ; k++)
{
Console.Write(answer[k]);
Console.Write(' ');
}
Console.Write(answer[k]);
return ;
}
}
}
在VS上测试没有问题,放到PAT上还是之前的错误求大神指点

我不知道错误错在哪里,还有我return 0了为啥还会有非零返回
PAT1005 继续(3n+1)猜想的更多相关文章
- PAT1005—— 继续(3n+1)猜想
卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候, ...
- 1001. 害死人不偿命的(3n+1)猜想 (15)
1001. 害死人不偿命的(3n+1)猜想 (15) 较简单,直接代码实现: #include <cstdio> int main() { int n; scanf("%d&qu ...
- 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 ...
- PAT乙级 1001. 害死人不偿命的(3n+1)猜想 (15)
1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...
- PAT-乙级-1001. 害死人不偿命的(3n+1)猜想 (15)
1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...
- 1001. 害死人不偿命的(3n+1)猜想
/* * Main.c * 1001. 害死人不偿命的(3n+1)猜想 * Created on: 2014年8月27日 * Author: Boomkeeper *********测试通过***** ...
- 9-9害死人不偿命的(3n+1)猜想
1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...
- PAT (Basic Level) Practice (中文)1001 害死人不偿命的(3n+1)猜想
1001 害死人不偿命的(3n+1)猜想 卡拉兹(Callatz)猜想: 对任何一个正整数 n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把 (3n+1) 砍掉一半.这样一直反复砍下去,最后一 ...
随机推荐
- 树莓派实现摄像头监控(使用motion和mjpg-streamer)
购买raspBerryCarmen,大概20元, 启动树莓派,安装: `sudo apt install motion` 配置/etc/motion/motion.conf, `sudo vim /e ...
- Spring Boot Mybatis简单使用
Spring Boot Mybatis简单使用 步骤说明 build.gradle:依赖添加 application.properties:配置添加 代码编写 测试 build.gradle:依赖添加 ...
- win系统常用命令
windows常用命令 net user 用户名 密码 /add (建立用户) net localgroup administrators 用户名 /add (将用户加到管理员,使其拥有管理权限) n ...
- 【C/C++开发】【Java开发】JNI的替代者—使用JNA访问Java外部功能接口
JNI的替代者-使用JNA访问Java外部功能接口 1. JNA简单介绍 先说JNI(Java Native Interface)吧,有过不同语言间通信经历的一般都知道,它允许Java代码和其他语言( ...
- 第10课.c++的新成员
1.动态内存分配 a.c++中通过new关键字进行动态内存申请 b.c++中的动态内存申请是基于类型进行的 c.delete关键字用于内存释放 2.new关键字与malloc函数的区别 a.new关键 ...
- python3正则表达式详细用法示例
转载自:https://www.runoob.com/python3/python3-reg-expressions.html
- VMware Conveter Standalone agent 安装时出现Error 29190错误的解决办法
官网上面找的: if it helps anyone else, i found a workaround for my particular issue. on the source machine ...
- Oracle-DQL 2- 限定和排序
1.where子句--查询30号部门员工的姓名,职位和工资SELECT ename,job,sal,deptno FROM empWHERE deptno = 30; --查询职位是manager的员 ...
- PAT 甲级真题题解(121-155)
1121 Damn Single 模拟 // 1121 Damn Single #include <map> #include <vector> #include <cs ...
- kettle转换设置变量,校验输出新变量
背景:有很多小的转换需要串联起来,如果前一个执行成功,后面继续接着执行,如果执行等待中,就让程序等一会再次获取数据分析,如果失败就中止,成功就进行下一个转换,以此类推.... 需求:通过job把参数传 ...