转跳点:

  ┗|`O′|┛ 嗷~~,这个该死的猜想又来了,难度升级了,如过没写过 P1001 的建议先去看一下。话不多说,看题。

  嗯,这道题就没有那么明确了,呃,也不能这么说,其实也挺明确。就是让你找出在输入样例中出现过但是没有在卡拉兹猜想演算过程中出现过的数。思路也很清晰,不用想的是,如果我们想知道哪个数没有出现,那么就得求出每一个卡拉兹猜想演算的过程出现的数,再记录下来。这个思路代表着我们无法减少卡拉兹计算次数,只能从存储和比较上做优化了,如果我每一个数都用数组把出现过的数都存起来,那么我们不仅浪费空间,而且找未出现的数的时候也十分浪费时间。为了减少时间与空间的成本,我们决定采用计数排序的思想来解决这个问题。

  

void Callatz(int num)
{
while (num != 1)
{
(num % 2) ? (num = (3 * num + 1) / 2) : (num /= 2);
if (num <= 100)
{
FlagArray[num]++; //
}
}
}

    这是计数过程,我们开辟了一个数组,长度大于100,每一步演算过程出现的数都会被 FlagArray[num]++; 所记录 。当我们进行寻找的时候只需要,找出从数组FlagArray的1~n中找到为0 的数即可。

思路比较简单,实现起来有点麻烦

下面是代码:

 1 #include <stdio.h>
2 #include <stdlib.h>
3 #define MAX_SIZE 110
4 int FlagArray[MAX_SIZE];
5 void Callatz(int num);
6 int cmp(const void *a, const void *b);
7
8 int main()
9 {
10 int n;
11 int NumsArray[MAX_SIZE], ans[MAX_SIZE];
12 scanf("%d", &n);
13
14 for (int i = 0; i < n; i++)
15 {
16 scanf("%d", &NumsArray[i]);
17 Callatz(NumsArray[i]);
18 }
19 int j = 0;
20 for (int i = 0; i < n; i++)
21 {
22 if (!FlagArray[NumsArray[i]])
23 {
24 ans[j++] = NumsArray[i];
25 printf("%d ", ans[j-1]);
26 }
27 }
28 putchar('\n');
29 qsort(ans, j, sizeof(int), cmp);
30 for (int i = 0; i < j; i++)
31 {
32 printf("%s%d", i ? " " : "", ans[i]);
33 }
34 putchar('\n');
35
36 return 0;
37 }
38
39 void Callatz(int num)
40 {
41 while (num != 1)
42 {
43 (num % 2) ? (num = (3 * num + 1) / 2) : (num /= 2);
44 if (num <= 100)
45 {
46 FlagArray[num]++;
47 }
48 }
49 }
50
51 int cmp(const void *a, const void *b)
52 {
53 return *(int *)b - *(int *)a;
54 }

  ——算法不易,诸君共勉!

P1005 继续(3n+1)猜想的更多相关文章

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  9. (数学) PTA 1005 继续(3n+1)猜想 (25 分)

    1005 继续(3n+1)猜想 (25 分) 卡拉兹(Callatz)猜想已经在1001中给出了描述.在这个题目里,情况稍微有些复杂. 当我们验证卡拉兹猜想的时候,为了避免重复计算,可以记录下递推过程 ...

随机推荐

  1. 碰到的问题——建设基于TensorFlow的深度学习环境

    1.解决jupyter notebook问题:socket.error: [Errno 99] Cannot assign requested address 首先要生成一个jupyter的配置文件: ...

  2. notepad++一次去掉所有空行,然后加上2个空行

    打开替换窗口,查找我的目标中填写: ^\r\n 替换为中不填,空着, 点击全部替换按钮. 如何给所有行添加2行空行: 打开替换窗口,查找目标中填写: \r\n 替换为中填写: \r\n\r\n\r\n ...

  3. ch8 固定宽度、流式、弹性布局

    假设浏览器窗口设置为1250px:wrapper的宽度为960px:content的宽度为920px:确保了wrapper居中时两边有20px的间距:  secondary的宽度为230px:  pr ...

  4. 本地jar在打包时打入到项目中去

    <dependency> <groupId>com.hxyc</groupId> <artifactId>hxyc-common</artifac ...

  5. IDEA设置窗口标签换行显示

    windows -> editor tabs -> tabs placement 关掉 show tabs in sigle row即可

  6. 8核AMD Zen加持:微软Surface这回血拼

    微软定于10月2日在纽约举办Surface新品发布会,几乎全线消费级产品都将更新,比如15英寸Surface Laptop 3. 最新爆料称,15寸Surface Laptop 3预计一口气推出6款型 ...

  7. HBase查询速度慢原因排查

    问题:通过HBase访问服务在HBase中查询 ASSET_NORMAL 表速度很慢 如下,查询一条数据需要2.970s时间: 如下,统计总条数需要14.675s时间: HBase访问服务部署了3个节 ...

  8. EASYUI TREE得到当前节点数据的GETDATA方法

    function show() { var node = $('#tt-c71').tree('getSelected'); var data = $('#tt-c71').tree('getData ...

  9. 报错信息 Context []startup failed due to previous errors

    文章转自:http://blog.sina.com.cn/s/blog_49b4a1f10100q93e.html 框架搭建好后,启动服务器出现如下的信息: log4j:WARN No appende ...

  10. Eclipse - 常见问题 - Refresh

    有时候项目代码正确但运行后出现异常,是因为eclipse没有刷新 (如jar包添加了但没用),比较脑慢. 解决方法: clean缓存,或者要多点几次Refresh,或者重启 eclipse.