书上具体所有题目:http://pan.baidu.com/s/1hssH0KO


代码:(Accepted,20 ms)

//UVa1594 - Ducci Sequence
#include<iostream>
#include<algorithm>
#include<cmath>
#include<vector>
using namespace std;
int T,N;
bool is_zero(vector<int> &d) {
for (const auto &i : d)
if (i) return false;
return true;
} int main()
{
//freopen("in.txt", "r", stdin);
scanf("%d", &T);
while (T--) {
scanf("%d", &N);
vector<int> D(N);
for (auto &i : D) scanf("%d", &i);
int i = -1;
while (++i<200) {
int D0 = D[0];
for (int i = 0;i < N-1;++i)
D[i] = abs(D[i] - D[(i + 1)]);
D[N - 1] = abs(D[N - 1] - D0);
if (is_zero(D)) break;
}
printf(i==200?"LOOP\n": "ZERO\n");
}
return 0;
}

题意:一个数组每次做一定变换,问最后他是循环了还是数据全都变成0了。


分析:模拟每一步,没什么思路。但是纯模拟量很大。

一开始我直接无限模拟每一步,看是不是全变成0了,还是有没有进入循环。

用了set来存储每一步的结果,用set的count函数来判断是不是进入循环了。代码如下:

//UVa1594 - Ducci Sequence
#include<iostream>
#include<algorithm>
#include<cmath>
#include<vector>
#include<set>
using namespace std;
int T,N;
bool is_zero(vector<int> &d) {
for (const auto &i : d)
if (i) return 0;
return 1;
} int main()
{
//freopen("in.txt", "r", stdin);
scanf("%d", &T);
while (T--) {
scanf("%d", &N);
vector<int> D(N);
set<vector<int> > P;
for (auto &i : D) scanf("%d", &i);
P.insert(D);
while (1) {
vector<int> D2(N);
for (int i = 0;i < N;++i)
D2[i] = abs(D[i] - D[(i + 1) % N]);
if (is_zero(D2)) { printf("ZERO\n"); break; }
if (P.count(D2)) { printf("LOOP\n"); break; }
D = D2;
P.insert(D);
}
}
return 0;
}

但是结果把我从椅子上吓得掉下去:“Time: 520 MS”!一口老血喷了出来(与上面最终提交的结果差了十万八千里!)。想了想,问题在哪里呢?于是去网上看了大神们的做法:他们都没有做数据是否循环的检查。原来如此,虽然set的检查已经很快了,但是如此庞大的检查量还是不敢恭维。直接不检查,1000次循环,要么出现全0,否则就是循环了,题目给你保证了不过1000的。现在知道了,原来还可以这么玩!

于是我又去除set的循环检查又提交一遍,100ms。那么与别人的40ms、50ms又差在哪儿呢?一看,人家只循环了500次甚至更少。为什么呢?我试了200,依然AC。想找点规律会不会保证它在200之内必有结果,没找出来。或许是题目的数据太水了原因。(本来猜想只要有一半的数字是一样的就应该是loop,想提交试试的,但是想想加个这样的判断并不合算)所以100ms差不多了。像我这样算是钻空子了。

[刷题]算法竞赛入门经典(第2版) 5-2/UVa1594 - Ducci Sequence的更多相关文章

  1. [刷题]算法竞赛入门经典(第2版) 4-6/UVa508 - Morse Mismatches

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,10 ms) //UVa508 - Morse Mismatches #include< ...

  2. [刷题]算法竞赛入门经典(第2版) 5-15/UVa12333 - Revenge of Fibonacci

    题意:在前100000个Fibonacci(以下简称F)数字里,能否在这100000个F里找出以某些数字作为开头的F.要求找出下标最小的.没找到输出-1. 代码:(Accepted,0.250s) / ...

  3. [刷题]算法竞赛入门经典(第2版) 5-13/UVa822 - Queue and A

    题意:模拟客服MM,一共有N种话题,每个客服MM支持处理其中的i个(i < N),处理的话题还有优先级.为了简化流程方便出题,设每个话题都是每隔m分钟来咨询一次.现知道每个话题前来咨询的时间.间 ...

  4. [刷题]算法竞赛入门经典(第2版) 4-5/UVa1590 - IP Networks

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1590 - IP Networks #include<iost ...

  5. [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation

    题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ...

  6. [刷题]算法竞赛入门经典(第2版) 6-6/UVa12166 - Equilibrium Mobile

    题意:二叉树代表使得平衡天平,修改最少值使之平衡. 代码:(Accepted,0.030s) //UVa12166 - Equilibrium Mobile //Accepted 0.030s //# ...

  7. [刷题]算法竞赛入门经典(第2版) 6-1/UVa673 6-2/UVa712 6-3/UVa536

    这三题比较简单,只放代码了. 题目:6-1 UVa673 - Parentheses Balance //UVa673 - Parentheses Balance //Accepted 0.000s ...

  8. [刷题]算法竞赛入门经典(第2版) 5-16/UVa212 - Use of Hospital Facilities

    题意:模拟患者做手术. 其条件为:医院有Nop个手术室.准备手术室要Mop分钟,另有Nre个恢复用的床.准备每张床要Mre分钟,早上Ts点整医院开张,从手术室手术完毕转移到回复床要Mtr分钟.现在医院 ...

  9. [刷题]算法竞赛入门经典(第2版) 5-11/UVa12504 - Updating a Dictionary

    题意:对比新老字典的区别:内容多了.少了还是修改了. 代码:(Accepted,0.000s) //UVa12504 - Updating a Dictionary //#define _XieNao ...

  10. [刷题]算法竞赛入门经典(第2版) 5-10/UVa1597 - Searching the Web

    题意:不难理解,照搬题意的解法. 代码:(Accepted,0.190s) //UVa1597 - Searching the Web //#define _XIENAOBAN_ #include&l ...

随机推荐

  1. 个人作业2——英语学习APP案例分析

    一.个人体验 1.下载并使用,描述最简单直观的个人第一次上手体验. ①入眼界面华丽,有正能量的名言警句配上很有意境的图片,界面美观. ②内容丰富,有许多精选英文文章,同时配有中文翻译,便于理解. ③能 ...

  2. javaScriptCore 实战 与 小结

      源码在这,看不懂的直接撸源码就行,转载声明出处 原生调用JS的大致流程,做了个思维简图 这是代码流程 // JS数据 func getJSVar() { let context: JSContex ...

  3. 01.Nodejs入门之Helloworld

    说明:本文章可供有一定js基础的朋友参考nodejs入门,本文未讲解nodejs的安装,如有需要的同学可以加QQ3382260752找我,进行交流学习. 1.新建文件夹helloworld demo, ...

  4. Java中类的继承,属性和方法的四种修饰符的作用范围,final关键字,java的三大特点中的2个:封装和多态,以及多态的一个设计模式,模板方法模式(template method)

    (一)Java中的继承: 关于继承,在Java中类的继承只能是单继承,不像C+++那样灵活,可以多继承,多继承的后果就是各种关系乱套,就相当于一个孩子有2个母亲一样,社会关系的复杂,不利于程序后期的开 ...

  5. web service 组件

    web service 组件 基本的 web service 平台是 XML + HTTP.所有标准的 web service 使用以下组件: SOAP(简单对象访问协议) UDDI(通用描述.发现与 ...

  6. DynamicObject扩展--实现JSON和DynamicObject的序列化与反序列化

    度娘许久,找不到我满意的答案,于是自己东凑西凑实现一个. DynamicObject扩展--实现JSON和DynamicObject的序列化与反序列化,亲测良好. 看代码 using System; ...

  7. 转接口IC GM7150BN/ GM7150BC:CVBS转BT656芯片 低功耗NTSC/PAL 视频解码器

    1 概述    GM7150 是一款9 位视频输入预处理芯片,该芯片采用CMOS 工艺,通过I2C 总线与PC 或DSP 相连构成应用系统.    它内部包含1 个模拟处理通道,能实现CVBS.S-V ...

  8. Git版本切换

    前面的话 本文将以一个简单实例的形式来介绍Git版本切换 初始版本 首先,在一个自定义的位置,创建目录a,比如在D盘下 [注意]本文会用到一些常用的Linux的Shell命令,详细信息移步至此 先使用 ...

  9. File类遍历目录及文件

    1. 构造函数 File(String args0)//使用一个表示文件或目录的路径的字符串创建一个File对象 File(URL args0)//使用一个URL对象创建File对象 File(Fil ...

  10. 【树莓派】修改树莓派盒子MAC地址

    用树莓派盒子,在某些客户方实施过程中,不同客户的网络环境对树莓派盒子的要求不同,网络管理配置要求MAC地址和IP绑定. 一种情况下,查询盒子的MAC地址,添加到网络管理的路由规则中即可: 另一种情况下 ...