[刷题]算法竞赛入门经典(第2版) 5-2/UVa1594 - Ducci Sequence
书上具体所有题目: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的更多相关文章
- [刷题]算法竞赛入门经典(第2版) 4-6/UVa508 - Morse Mismatches
书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,10 ms) //UVa508 - Morse Mismatches #include< ...
- [刷题]算法竞赛入门经典(第2版) 5-15/UVa12333 - Revenge of Fibonacci
题意:在前100000个Fibonacci(以下简称F)数字里,能否在这100000个F里找出以某些数字作为开头的F.要求找出下标最小的.没找到输出-1. 代码:(Accepted,0.250s) / ...
- [刷题]算法竞赛入门经典(第2版) 5-13/UVa822 - Queue and A
题意:模拟客服MM,一共有N种话题,每个客服MM支持处理其中的i个(i < N),处理的话题还有优先级.为了简化流程方便出题,设每个话题都是每隔m分钟来咨询一次.现知道每个话题前来咨询的时间.间 ...
- [刷题]算法竞赛入门经典(第2版) 4-5/UVa1590 - IP Networks
书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 代码:(Accepted,0 ms) //UVa1590 - IP Networks #include<iost ...
- [刷题]算法竞赛入门经典(第2版) 6-7/UVa804 - Petri Net Simulation
题意:模拟Petri网的执行.虽然没听说过Petri网,但是题目描述的很清晰. 代码:(Accepted,0.210s) //UVa804 - Petri Net Simulation //Accep ...
- [刷题]算法竞赛入门经典(第2版) 6-6/UVa12166 - Equilibrium Mobile
题意:二叉树代表使得平衡天平,修改最少值使之平衡. 代码:(Accepted,0.030s) //UVa12166 - Equilibrium Mobile //Accepted 0.030s //# ...
- [刷题]算法竞赛入门经典(第2版) 6-1/UVa673 6-2/UVa712 6-3/UVa536
这三题比较简单,只放代码了. 题目:6-1 UVa673 - Parentheses Balance //UVa673 - Parentheses Balance //Accepted 0.000s ...
- [刷题]算法竞赛入门经典(第2版) 5-16/UVa212 - Use of Hospital Facilities
题意:模拟患者做手术. 其条件为:医院有Nop个手术室.准备手术室要Mop分钟,另有Nre个恢复用的床.准备每张床要Mre分钟,早上Ts点整医院开张,从手术室手术完毕转移到回复床要Mtr分钟.现在医院 ...
- [刷题]算法竞赛入门经典(第2版) 5-11/UVa12504 - Updating a Dictionary
题意:对比新老字典的区别:内容多了.少了还是修改了. 代码:(Accepted,0.000s) //UVa12504 - Updating a Dictionary //#define _XieNao ...
- [刷题]算法竞赛入门经典(第2版) 5-10/UVa1597 - Searching the Web
题意:不难理解,照搬题意的解法. 代码:(Accepted,0.190s) //UVa1597 - Searching the Web //#define _XIENAOBAN_ #include&l ...
随机推荐
- 走入PHP-初次见面
FROM:实验楼 Linux启动WEB服务器: $ sudo service apache2 start 新建并打开test.php文件: $ sudo gvim /path/test.php PHP ...
- CrawlScript脚本语言实现网络爬虫
前段时间我们学习了几种爬虫技术,我们来回顾一下,webCollector,htmlParser,Jsoup,各有优劣,但是如果能灵活运用,其实都是很不错的.那么,今天呢,我们来学习一种脚本语言,这是一 ...
- css中的inline-block
div { display: inline-block; *display: inline; *zoom: 1; } Basic Support包含值:none | inline | block | ...
- python 之tornado 入门
#!/usr/bin/env python # -*- coding:utf-8 -*- # --------------------------------------- # email : gen ...
- aps.net验证控件的异常处理
异常错误信息: WebForms UnobtrusiveValidationMode 需要"jQuery"ScriptResourceMapping.请添加一个名为 jquery ...
- 分享一个低配VPS下运行的mysql配置文件
在各种内存CPU核心只有1/2核,内存只有512M/1G的vps下,内存.CPU.硬盘都不是太充裕.因此主要思路是,禁止吃内存大户innodb引擎,默认使用MyISAM.禁止吃硬盘大户log-bin, ...
- ubuntu12.04下编译chrome
1,直接下载压缩包: http://chromium-browser-source.commondatastorage.googleapis.com/chromium_tarball.html 2,安 ...
- WebService基础学习(三)—CXF
一.什么是CXF? Apache CXF = Celtix + Xfire,开始叫 Apache CeltiXfire,后来更名为 Apache CXF 了,以下简称为 CXF.Apache ...
- Android中实现定时器的四种方式
第一种方式利用Timer和TimerTask 1.继承关系 java.util.Timer 基本方法 schedule 例如: timer.schedule(task, delay,period); ...
- jquery 中 eq()遍历方法 和:eq()选择器的区别
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...