zcmu-2100
2100: 蘭頓螞蟻
Time Limit:?1 Sec??Memory Limit:?128 MBSubmit:?44??Solved:?27
[Submit][Status][Web Board]
Description
? ? ? ?蘭頓螞蟻,是于1986年,由克里斯·蘭頓提出來的,屬于細胞自動機的一種。
平面上的正方形格子被填上黑色或白色。在其中一格正方形內有一只“螞蟻”。
螞蟻的頭部朝向為:上下左右其中一方。
螞蟻的移動規則十分簡單:
若螞蟻在黑格,右轉90度,將該格改為白格,并向前移一格;
若螞蟻在白格,左轉90度,將該格改為黑格,并向前移一格。
規則雖然簡單,螞蟻的行為卻十分復雜。剛剛開始時留下的路線都會有接近對稱,像是會重復,但不論起始狀態如何,螞蟻經過漫長的混亂活動后,會開辟出一條規則的“高速公路”。
螞蟻的路線是很難事先預測的。
你的任務是根據初始狀態,用計算機模擬蘭頓螞蟻在第n步行走后所處的位置。
Input
輸入數據的第一行是 m n 兩個整數(3 < m, n < 100),表示正方形格子的行數和列數。
接下來是 m 行數據。
每行數據為 n 個被空格分開的數字。0 表示白格,1 表示黑格。
接下來是一行數據:x y s k, 其中x y為整數,表示螞蟻所在行號和列號(行號從上到下增長,列號從左到右增長,都是從0開始編號)。s 是一個大寫字母,表示螞蟻頭的朝向,我們約定:上下左右分別用:UDLR表示。k 表示螞蟻走的步數。
Output
輸出數據為兩個空格分開的整數 p q, 分別表示螞蟻在k步后,所處格子的行號和列號。
Sample Input
5 60 0 0 0 0 00 0 0 0 0 00 0 1 0 0 00 0 0 0 0 00 0 0 0 0 02 3 L 5Sample Output
1 3HINT
Source
#include<iostream> #include<cstdio> #include<cmath> #include<cstring> #include<cstdlib> #include<vector> #include<stack> #include<queue> #include<map> #include<set> #include<list> #include<ctime> #include<algorithm> using namespace std;char c; int x,y,k; int main() {int m,n;scanf("%d%d",&m,&n);int i[105][105];for(int a = 0; a < m; a ++)for(int b = 0; b< n; b ++)scanf("%d",&i[a][b]);scanf("%d %d %c %d",&x,&y,&c,&k);while(k--){if(i[x][y]==1){if(c=='U')c='R';else if(c=='R')c='D';else if(c=='D')c='L';else if(c=='L')c='U';i[x][y]=0;}else{if(c=='U')c='L';else if(c=='L')c='D';else if(c=='D')c='R';else if(c=='R')c='U';i[x][y]=1;}if(c=='U')x--;else if(c=='D')x++;else if(c=='L')y--;else if(c=='R')y++;}printf("%d %d\n",x,y);return 0; }總結
- 上一篇: zcmu-2099
- 下一篇: Mysql 给你100万条数据的一