卡拉兹(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)猜想的更多相关文章

  1. PAT1005—— 继续(3n+1)猜想

    卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程中遇到的每一个数.例如对n=3进行验证的时候, ...

  2. 1001. 害死人不偿命的(3n+1)猜想 (15)

    1001. 害死人不偿命的(3n+1)猜想 (15) 较简单,直接代码实现: #include <cstdio> int main() { int n; scanf("%d&qu ...

  3. PAT 乙级 1005. 继续(3n+1)猜想 (25)

    1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B   卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情 ...

  4. PAT乙级 1005. 继续(3n+1)猜想 (25)

    1005. 继续(3n+1)猜想 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Callatz ...

  5. PAT乙级 1001. 害死人不偿命的(3n+1)猜想 (15)

    1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...

  6. PAT-乙级-1001. 害死人不偿命的(3n+1)猜想 (15)

    1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...

  7. 1001. 害死人不偿命的(3n+1)猜想

    /* * Main.c * 1001. 害死人不偿命的(3n+1)猜想 * Created on: 2014年8月27日 * Author: Boomkeeper *********测试通过***** ...

  8. 9-9害死人不偿命的(3n+1)猜想

    1001. 害死人不偿命的(3n+1)猜想 (15) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 卡拉兹(Ca ...

  9. PAT (Basic Level) Practice (中文)1001 害死人不偿命的(3n+1)猜想

    1001 害死人不偿命的(3n+1)猜想 卡拉兹(Callatz)猜想: 对任何一个正整数 n,如果它是偶数,那么把它砍掉一半:如果它是奇数,那么把 (3n+1) 砍掉一半.这样一直反复砍下去,最后一 ...

随机推荐

  1. 快速搭建WordPress博客

    博主在看了朋友的博客后 决定也搭建一个wordPress 博客 思路 1.购买服务器 2.Cenots环境配置 3.安装wordpress 工具 推荐使用 Xshell 6,当然也可以用其他 服务器推 ...

  2. go爬虫系列

    一.go语言爬取豆瓣电影top250 package main import ( "net/http" "io/ioutil" "os" & ...

  3. centos7 的system

    1.vim /etc/systemd/system/alertmanager.service [Unit] Description=Alertmanager After=network-online. ...

  4. elasticsearch 常用查询 + 删除索引 + 集群状态诊断

    1.多条件查询 curl -X POST \ http://10.0.0.42:9200/addressbook_user/_search \ -H 'cache-control: no-cache' ...

  5. 使用echo $? 查看命令成功执行的原理

    转载于:http://blog.csdn.net/cmzsteven/article/details/49049387 在进行源代码编译,或者执行命令无法确认所执行的命令是否成功执行的情况下,我们都会 ...

  6. 【Python】【demo实验24】【练习实例】【打印图样】

    原题: 打印出如下图案(菱形): * *** ***** ******* ***** *** * 我的源码: #!/usr/bin/python # encoding=utf-8 # -*- codi ...

  7. 2019-07-31 C#基础知识学习

    什么是进程:进程是系统中正在运行的一个程序,程序一旦运行就是进程. 什么是线程:线程是进程的一个实体,是进程的一条执行路径. 进程和线程的区别体现在以下几个方面: 1.地址空间和其他资源(如打开文件) ...

  8. GIP画图

    世界坐标:相对于winform窗体来说的, 页面坐标:相对于控件的 设置坐标:相对于显示器 获得Graphics对象一般有两种方式: 1.控件.CreateGraphics();//通过该方式创建后要 ...

  9. Java笔记1: 输入输出与变量常量

    输入方法 nextLine 以Enter为结束符,也就是说 nextLine()方法返回的是输入回车之前的所有字符. 可以获得空白的一串字符. import java.util.Scanner; pu ...

  10. HDU - 1045 Fire Net (二分图最大匹配-匈牙利算法)

    (点击此处查看原题) 匈牙利算法简介 个人认为这个算法是一种贪心+暴力的算法,对于二分图的两部X和Y,记x为X部一点,y为Y部一点,我们枚举X的每个点x,如果Y部存在匹配的点y并且y没有被其他的x匹配 ...