[刷题]算法竞赛入门经典(第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 ...
随机推荐
- nginx浏览目录
[root@localhost domains]# vi web.jd.com location / proxy_set_header X-Forwarded-For $proxy_add_x_for ...
- div背景图片或颜色不显示的解决办法
背景图片不显示的原因: 1. css没有被调用 2. css图片地址不对 3. div的高度没有固定,是auto.没有设值或者高度不够 4. div被嵌套 5. div代码不规范 解决办法: (1)D ...
- ElasticSearch查询 第五篇:布尔查询
布尔查询是最常用的组合查询,不仅将多个查询条件组合在一起,并且将查询的结果和结果的评分组合在一起.当查询条件是多个表达式的组合时,布尔查询非常有用,实际上,布尔查询把多个子查询组合(combine)成 ...
- yii2-验证规则,rules,判断条件
yii2模型的验证规则,简单的使用我就不详细说了,想看的可以去看官网教程http://www.yiichina.com/doc/guide/2.0/structure-models#validatio ...
- 【算法功底】LeetCode 292 Nim Game
You are playing the following Nim Game with your friend: There is a heap of stones on the table, eac ...
- 什么是RESTful?
RESTful一种软件架构风格,设计风格而不是标准,只是提供了一组设计原则和约束条件.它主要用于客户端和服务器交互类的软件.基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制. REST ...
- MySQL用户认证及权限grant-revoke
一.MySQL用户认证: 登录并不属于访问控制机制,而属于用户身份识别和认证: 1.用户名-user 2.密码-password 3.登录mysqld主机-host 实现用户登录MySQL,建立连接. ...
- 关于string类型定义占几个字节??
测试代码: #include <iostream>using namespace std;int main(void){ string name; cout<<"si ...
- jQuery制作右侧边垂直二级导航菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- js中将yyyy-MM-dd格式的日期转换
1.转换为yyyy年MM月dd日 var str = "2017-02-16"; var reg =/(\d{4})\-(\d{2})\-(\d{2})/; var date = ...