题目: X 星球的一处迷宫游乐场建在某个小山坡上。它是由 10 \times 1010×10 相互连通的小房间组成的。 房间的地板上写着一个很大的字母。我们假设玩家是面朝上坡的方向站立,则: LL 表示走到左边的房间, RR 表示走到右边的房间, UU 表示走到上坡方向的房间, DD 表示走到下坡方向的房间。 X 星球的居民有点懒,不愿意费力思考。他们更喜欢玩运气类的游戏。这个游戏也是如此! 开始的时候,直升机把 100100 名玩家放入一个个小房间内。玩家一定要按照地上的字母移动。 迷宫地图如下: UDDLUULRUL UURLLLRRRU RRUURLDLRD RUDDDDUUUU URUDLLRRUU DURLRLDLRL ULLURLLRDU RDLULLRDDD UUDDUDUDLL ULRDLUURRR 请你计算一下,最后,有多少玩家会走出迷宫,而不是在里边兜圈子? //解法一: #include <iostream> using namespace std; #include<string.h> string a[10]; int vis[10][10]; bool solve(int i,int j){ if(i<0 || j<0 || i>9 || j>9){ return true; } if(vis[i][j] == 1){ return false; } vis[i][j] = 1; switch(a[i][j]){ case 'U': return solve(i-1,j); case 'L': return solve(i,j-1); case 'R': return solve(i,j+1); case 'D': return solve(i+1,j); default: return false; } } int main() { int num = 0; a[0] = "UDDLUULRUL"; a[1] = "UURLLLRRRU"; a[2] = "RRUURLDLRD"; a[3] = "RUDDDDUUUU"; a[4] = "URUDLLRRUU"; a[5] = "DURLRLDLRL"; a[6] = "ULLURLLRDU"; a[7] = "RDLULLRDDD"; a[8] = "UUDDUDUDLL"; a[9] = "ULRDLUURRR"; for(int i=0;i<10;i++){ for(int j=0;j<10;j++){ memset(vis,0,sizeof(vis)); cout<<a[i][j]<<" "; bool c=solve(i,j); if(c){ num++; } } cout<<endl; } std::cout << num << std::endl; return 0; } //解法二: #include <iostream> using namespace std; #include<string.h> char a[10][10]; int vis[10][10]; bool solve(int i,int j){ if(i<0 || j<0 || i>9 || j>9){ return true; } if(vis[i][j] == 1){ return false; } vis[i][j] = 1; switch(a[i][j]){ case 'U': return solve(i-1,j); case 'L': return solve(i,j-1); case 'R': return solve(i,j+1); case 'D': return solve(i+1,j); default: return false; } } int main() { int num = 0; for(int i=0;i<10;i++){ for(int j=0;j<10;j++){ cin>>a[i][j]; } } for(int i=0;i<10;i++){ for(int j=0;j<10;j++){ memset(vis,0,sizeof(vis)); bool c=solve(i,j); if(c){ num++; } } } std::cout << num << std::endl; return 0; }
0.0分
1 人评分
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:543 |
C语言程序设计教程(第三版)课后习题7.1 (C语言代码)浏览:761 |
【偶数求和】 (C语言代码)浏览:674 |
C语言训练-数字母 (C语言代码)浏览:670 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:863 |
C语言程序设计教程(第三版)课后习题6.3 (C语言代码)浏览:687 |
1126题解浏览:649 |
1128题解(返回值为数组的情况)浏览:571 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:721 |
1250题解浏览:603 |