POJ1059 Chutes and Ladders
题目来源:http://poj.org/problem?id=1059
题目大意:
有一种叫做“Chutes and Ladders”(梯子和滑梯)的简单游戏。游戏在一块棋盘上进行,棋盘上有编号从1-100的格子,玩家们从假定的编号为0的格子处出发。各玩家轮流投掷色子(上有数字1-6),色子的数字表示玩家在棋盘上将前进的步数,最先到达100号格子的玩家胜利。
当然游戏不会仅仅这么无聊。在棋盘上不同的格子之间可能通过Ladder(梯子,从编号小的格子连至编号大的格子)和“Chute”(滑梯,从编号大的格子连至编号小的格子)连接起来。如果,一次投色子后前进到达的格子处是ladder或chute的起点,则玩家将到达ladder或chute通向的格子。注意:终点格子处的ladder和chute都是无效的,但起点处的有效。
此外,有一些特殊的格子:写有“miss-a-turn”的格子表示玩家一旦到达它们,将失去下一轮的投色子前进机会,写有“extra-turn”的格子表示玩家可以立即再投一次色子再前进一次。起点和终点处的格子都不会是这两种特殊格子。
如果一个玩家当前处于编号95以上的格子处,如果它们投掷的色子使它们前进的终点超过了100,那么这次这次投掷将被忽略。
输入:输入的开始为少于1000次的色子投掷结果,每个都是1到6的整数,由6表示结束。
接下来是一个或多个游戏数据集。每个数据集包含三个部分。
第一部分:一行表示游戏中的玩家数,多于1少于6。
第二部分:棋盘中的ladders和chutes. ladders和chutes每个都由两个1-99的整数表示起点和终点。当遇到一行“0 0”时表示该部分结束。
第三部分:棋盘中的“miss-a-turn”格和“extra-turn”格。每行一个,如果数字是负数说明是“miss-a-turn”, 正数说明是“extra-turn”(例如:-15表示15号格是"miss-a-turn"格, 25表示25号格是“extra-turn”).0表示该部分结束。
输出:每轮游戏对应1行,输出该轮游戏的赢家编号,输入已保证会找到赢家。
Sample Input
3 6 3 2 5 1 3 4 2 3 1 2 0
2
6 95
99 1
0 0
-3
98
0
2
3 99
6 90
0 0
0
0
Sample Output
2
2
模拟题水过。
////////////////////////////////////////////////////////////////
// POJ1059 Chutes and Ladders
// Memory: 228K Time: 0MS
// Language: C++ Result : Accepted
/////////////////////////////////////////////////////////////// #include <iostream>
#include <algorithm> using namespace std; struct Ladder {
int start;
int end;
}; int die[];
int counter[];
bool trapped[];
int player_num;
Ladder ladders[];
int ladder_cnt;
bool miss_turn[];
bool extra_turn[]; int cmp(Ladder &a, Ladder &b) {
return a.start <= b.start;
} int bin_seach(int v, int s, int e) {
if (s > v || v > ladders[e].start || v < ladders[s].start) {
return -;
}
int mid = (s + e) / ;
if (v == ladders[mid].start) {
return ladders[mid].end;
} else if (v < ladders[mid].start) {
return bin_seach(v, s, mid - );
} else {
return bin_seach(v, mid + , e);
}
} int main(void) { //读入色子投掷结果
for (int i = ; i < ; ++i) {
cin >> die[i];
if (die[i] == ) {
break;
}
} while (cin >> player_num && player_num > ) { //读取玩家数
memset(miss_turn, false, sizeof(miss_turn));
memset(extra_turn, false, sizeof(extra_turn));
memset(counter, , sizeof(counter));
memset(ladders, , sizeof(ladders));
ladder_cnt = ; //读取ladders
while (true) {
cin >> ladders[ladder_cnt].start >> ladders[ladder_cnt].end;
if (ladders[ladder_cnt].start == ) {
break;
}
++ladder_cnt;
} //ladders排序
sort(ladders, ladders + ladder_cnt, cmp); //读入miss-a-turn和extra-turn
while (true) {
int t;
cin >> t;
if (t > ) {
extra_turn[t] = true;
} else if (t < ) {
miss_turn[- * t] = true;
} else {
break;
}
} //Game starts!
int player_id = ;
int die_pointer = ;
while (true) { int current = counter[player_id]; //当前位置
int die_num = die[die_pointer++]; //色子投掷结果
int des = current + die_num; //目标位置 if (current == ) {
cout << player_id + << endl;
break;
} //当前玩家被困
if (trapped[player_id]) {
trapped[player_id++] = false;
player_id %= player_num;
continue;
} //恰好到达终点,结束
if (des == ) {
cout << player_id + << endl;
break;
}
//超过100,忽略该次
else if (des > ) {
(++player_id) %= player_num;
continue;
} counter[player_id] = des; //判断该处是否有ladder或chute
des = bin_seach(counter[player_id], , ladder_cnt - );
if (des != -) {
counter[player_id] = des;
} //判断该处是否为miss-a-turn或extra-turn
if (miss_turn[counter[player_id]] == true) {
trapped[player_id] = true;
}
if (extra_turn[counter[player_id]] == true) {
continue;
}
(++player_id) %= player_num;
}
}
return ;
}
POJ1059 Chutes and Ladders的更多相关文章
- POJ题目排序的Java程序
POJ 排序的思想就是根据选取范围的题目的totalSubmittedNumber和totalAcceptedNumber计算一个avgAcceptRate. 每一道题都有一个value,value ...
- Swift流程控制之循环语句和判断语句详解
Swift提供了所有c类语言的控制流结构.包括for和while循环来执行一个任务多次:if和switch语句来执行确定的条件下不同的分支的代码:break和continue关键字能将运行流程转到你代 ...
- Swift编程语言学习4.1——周期
Swift它提供了类似 C 流量控制结构语言,它包含运行多个任务的能力for和while周期.选择根据不同的编码分支机构的具体条件来运行if和switch声明,有控制流程跳转到其他代码break和co ...
- 精选 TOP45 值得学习的Python项目
精选 TOP45 值得学习的Python项目 [导读]热门资源博客 Mybridge AI 比较了 18000 个关于 Python 的项目,并从中精选出 45 个最具竞争力的项目.我们进行了翻译,在 ...
- 值得收藏的45个Python优质资源
REST API:使用 Python,Flask,Flask-RESTful 和 Flask-SQLAlchemy 构建专业的 REST API https://www.udemy.com/rest- ...
- Welcome-to-Swift-05控制流(Control Flow )
Swift提供了所有c类语言的控制流结构.包括for和while循环来执行一个任务多次:if和switch语句来执行确定的条件下不同的分支的代码:break和continue关键字能将运行流程转到你代 ...
- 值得收藏的45个Python优质资源(附链接)
REST API:使用 Python,Flask,Flask-RESTful 和 Flask-SQLAlchemy 构建专业的 REST API https://www.udemy.com/rest- ...
- Python学习教程(十)精选 TOP45 值得学习的Python项目
精选 TOP45 值得学习的Python项目 [导读]热门资源博客 Mybridge AI 比较了 18000 个关于 Python 的项目,并从中精选出 45 个最具竞争力的项目.我们进行了翻译,在 ...
- [lightoj P1151] Snakes and Ladders
1151 - Snakes and Ladders Time Limit: 2 second(s) Memory Limit: 32 MB 'Snakes and Ladders' or 'Sh ...
随机推荐
- python jvm数据
在网上找的抱歉忘了原链接了额 #!/usr/bin/env python # # import os import commands import re import sys (status1, re ...
- Eclipse Maven 编译错误 Dynamic Web Module 3.0 requires Java 1.6 or newer 解决方案
Eclipse Maven 开发一个 jee 项目时,编译时遇到以下错误:Description Resource Path Location TypeDynamic Web Module 3.0 r ...
- python爬虫实战(2)--爬取百度贴吧
本篇目标 1.对百度贴吧的任意帖子进行抓取 2.指定是否只抓取楼主发帖内容 3.将抓取到的内容分析并保存到文件 1.URL格式的确定 先观察百度贴吧url格式,以中南财经政法大学迎新帖为例,URL我们 ...
- 使用GSON来生成JSON数据
第二种方法: 当不需要显示某个属性时,在不需要显示出的属性前加transient关键字即可满足 使用gson来解析 使用gson解析 带日期转换 集合类解析:gson中的数组与java中集合类都是对应 ...
- spring配置c3p0连接池
- 下拉框value ,selectedIndex
- Configuration File (php.ini) Path Loaded Configuration File 都有加载php.ini文件,有什么不同的地方?
Configuration File (php.ini) Path /usr/local/php7/etc 这个目录下面也有php.ini文件(如果在编译./configure -with- ...
- R: 判别分析
判别与聚类的比较: 聚类分析和判别分析有相似的作用,都是起到分类的作用. 判别分析是已知分类然后总结出判别规则,是一种有指导的学习: 聚类分析则是有了一批样本,不知道它们的分类,甚至连分成几类也不知道 ...
- 101334E Exploring Pyramids
传送门 题目大意 看样例,懂题意 分析 实际就是个区间dp,我开始居然不会...详见代码(代码用的记忆化搜索) 代码 #include<iostream> #include<cstd ...
- Luogu 4777 【模板】扩展中国剩余定理(EXCRT)
复习模板. 两两合并同余方程 $x\equiv C_{1} \ (Mod\ P_{1})$ $x\equiv C_{2} \ (Mod\ P_{2})$ 把它写成不定方程的形式: $x = C_{1} ...