NOIP 2012 普及组 第二题 寻宝
2013-07-22 13:05
375 查看
在Vijos上测试成功。
测试数据 #0: Accepted, time = 0 ms, mem = 25284 KiB, score = 10
测试数据 #1: Accepted, time = 0 ms, mem = 25284 KiB, score = 10
测试数据 #2: Accepted, time = 0 ms, mem = 25280 KiB, score = 10
测试数据 #3: Accepted, time = 54 ms, mem = 25288 KiB, score = 10
测试数据 #4: Accepted, time = 89 ms, mem = 25284 KiB, score = 10
测试数据 #5: Accepted, time = 589 ms, mem = 25288 KiB, score = 10
测试数据 #6: Accepted, time = 628 ms, mem = 25280 KiB, score = 10
测试数据 #7: Accepted, time = 593 ms, mem = 25280 KiB, score = 10
测试数据 #8: Accepted, time = 800 ms, mem = 25280 KiB, score = 10
测试数据 #9: Accepted, time = 824 ms, mem = 25280 KiB, score = 10
有点慢。
模拟一下就好了。
一开始用cin/cout和模超了5个点。后来改用scanf/printf和减法就好了。。。。(模这个东西真是慢)
大循环是循环每个楼层。
然后计算指示牌的和(就加一下就好了)。
然后扫描该层向上楼梯,存到一个数组里。
然后模一下就找到下一个楼梯。
循环下去就好了。
测试数据 #0: Accepted, time = 0 ms, mem = 25284 KiB, score = 10
测试数据 #1: Accepted, time = 0 ms, mem = 25284 KiB, score = 10
测试数据 #2: Accepted, time = 0 ms, mem = 25280 KiB, score = 10
测试数据 #3: Accepted, time = 54 ms, mem = 25288 KiB, score = 10
测试数据 #4: Accepted, time = 89 ms, mem = 25284 KiB, score = 10
测试数据 #5: Accepted, time = 589 ms, mem = 25288 KiB, score = 10
测试数据 #6: Accepted, time = 628 ms, mem = 25280 KiB, score = 10
测试数据 #7: Accepted, time = 593 ms, mem = 25280 KiB, score = 10
测试数据 #8: Accepted, time = 800 ms, mem = 25280 KiB, score = 10
测试数据 #9: Accepted, time = 824 ms, mem = 25280 KiB, score = 10
有点慢。
模拟一下就好了。
一开始用cin/cout和模超了5个点。后来改用scanf/printf和减法就好了。。。。(模这个东西真是慢)
大循环是循环每个楼层。
然后计算指示牌的和(就加一下就好了)。
然后扫描该层向上楼梯,存到一个数组里。
然后模一下就找到下一个楼梯。
循环下去就好了。
#include <stdio.h> #include <string.h> using namespace std; #define N 10005 #define M 105 typedef long long ll; ll n, m, now, i, j; ll up [M], card [M], louti[M], loutitot , lt [M]; ll mod(ll s, ll m) { ll r = s; while(r>=m) r-=m; return r; } int main() { scanf("%lld%lld", &n, &m); memset(loutitot,0,sizeof(loutitot)); for(i=1;i<=n;i++) for(j=0;j<m;j++) scanf("%d%d", &up[i][j], &card[i][j]); scanf("%d", &now); ll sum = 0; for(i=1;i<=n;i++) { sum = mod(sum+card[i][now],20123); ll d = card[i][now]; ll k = 0; for(j=now;j<m;j++) if(up[i][j]) louti[++k] = j; for(j=0;j<now;j++) if(up[i][j]) louti[++k] = j; d=mod(d,k); if(d==0) d=k; now=louti[d]; } printf("%lld", sum); return 0; }
相关文章推荐
- NOIP2012-普及组复赛-第二题-寻宝
- B. 【NOIP2012普及组真题】 寻宝
- NOIP2012普及组-寻宝
- 【NOIP2012普及组原题】寻宝
- NOIP2012普及组-寻宝
- 【模拟】【noip2012普及组】寻宝
- 【NOIP2012普及】寻宝
- NOIP2012普及组-摆花
- JZOJ(中山纪中) 2018.01.26【NOIP普及组】模拟赛D组 第二题
- JZOJ(中山纪中) 2018.02.01【NOIP普及组】模拟赛D组 第二题
- luogu1075 质因数分解(NOIP2012普及组第1题)
- 【NOIP2012普及】摆花
- 摆花 NOIP2012普及
- NOIP2012普及组解题报告
- [普及] NOIP 2012 文化之旅
- NOIP2011-普及组复赛-第二题-统计单词数
- C. 【NOIP2012普及组真题】 摆花
- NOIP2010-普及组复赛模拟试题-第二题-数字积木
- 二分查找or线段树(借教室洛谷1083vijos1782NOIP 2012 提高组 第二天 第二题)
- [Noip2012普及组]摆花