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 ...
随机推荐
- 关于RandomizedSearchCV 和GridSearchCV(区别:参数个数的选择方式)
# -*- coding: utf-8 -*- """ Created on Tue Aug 09 22:38:37 2016 @author: Administrato ...
- Java Swing 如何让窗体居中显示
如题,其他不多说,直接上代码! package com.himarking.tool; import java.awt.Toolkit; import javax.swing.JFrame; @Sup ...
- Python的安装以及路径的设置(python的下载地址:www.python.org)
在有的Python版本中在安装时,我们的可以再安装时选择Python路径的自动配备 在选择python的安装程序的时候,我们尽量选择python的2.版本,因为随着Python的更新,Python的数 ...
- CSS制作水平垂直居中对齐 多种方式各有千秋
作为前端攻城师,在制作Web页面时都有碰到CSS制作水平垂直居中,我想大家都有研究过或者写过,特别的其中的垂直居中,更是让人烦恼.这段时间,我收 集了几种不同的方式制作垂直居中方法,但每种方法各有千秋 ...
- 如何选择RDBMS关系型数据库和Nosql非关系型数据库?
RDBMS关系型数据库和Nosql非关系型数据库区别: 一.RDBMS是关系型数据库模式: 1.二维模式,由行列组成. 2.非常强调事务原子性,例如用户提出一个请求,DB完整的去执行,如果报错就全部回 ...
- JQuery利用css()修改样式后 hover失效的解决办法
执行完代码后发现写在样式表中的hover效果失效,改了好几遍差点重新写函数,后来发现很简单,是优先级的问题,css()中的内容覆盖了之前的样式 只需要在样式后写!important即可解决! .fil ...
- Codeforces 1107E (Vasya and Binary String) (记忆化,DP + DP)
题意:给你一个长度为n的01串,和一个数组a,你可以每次选择消除一段数字相同的01串,假设消除的长度为len,那么收益为a[len],问最大的收益是多少? 思路:前两天刚做了POJ 1390,和此题很 ...
- centos系统查看本机IP地址
centos系统查看本机IP地址,输入 ifconfig -a查看 centos查询上网公网IP输入 curl ifconfig.me 命令即可查看 centos查询上网网关IP,tracepath ...
- Linux 控制台/终端/tty/shell
一.简介 使用linux已经有一段时间,却一直弄不明白这几个概念之间的区别.这些概念本身有着非常浓厚的历史气息,随着时代的发展,他们的含义也在发生改变,它们有些已经失去了最初的含义,但是它们的名字却被 ...
- hdu4283 You Are the One
传送门 题目 The TV shows such as You Are the One has been very popular. In order to meet the need of boys ...