输入包含多组数据,请处理到文件结束。
每组数据,第一行2个整数n、m,表示地的尺寸。
之后n行,每行m个英文字母,大写的T表示这里种有苹果树,小写的i表示这里放有iPhone,其他字符表示这里什么也没有。
之后1行,一个整数Q,表示小W询问的次数。
之后Q行,包含3个整数,可能有以下情况:
1 i1 j1 表示小W想知道第i1行第j1列的方块中有什么东西。
2 i1 i2 表示亮亮交换了第i1行与第i2行。
3 j1 j2 表示亮亮交换了第j1列与第j2列。
对于100%的数据,有1<=n*m<=106,1<=Q<=105,1<=i1, i2<=n,1<=j1, j2<=m。
对于每组数据,输出以一行“Case #x:”开头,x表示数据的编号,从1开始。
对于小W的每次格式为“1 i j”的询问,输出一行。若方块中是苹果树,输出"Tree"。若方块中是iPhone,输出“Phone”。若方块中什么也没有,输出“Empty”。
#include <stdio.h>
int main(){
int m,n;
int total = 0;
while (scanf("%d %d",&n,&m) != EOF) {
total ++;
printf("Case #%d:\n",total);
char field[n+1][m+1];
int nown[n+1],nowm[m+1];
int i,j;
for (i=1;i<=m;i++) nowm[i] = i;
for (i=1;i<=n;i++){
char row[1000001];
nown[i] = i;
scanf("%s",row);
for (j=1;j<=m;j++){
field[i][j] = row[j-1];
}
}
int q;
scanf("%d",&q);
for (i=1;i<=q;i++){
int order,i1,i2;
scanf("%d %d %d",&order,&i1,&i2);
if (order == 1){
char now = field[nown[i1]][nowm[i2]];
if (now == ‘T‘){
printf("Tree\n");
}
else if (now == ‘i‘){
printf("Phone\n");
}
else printf("Empty\n");
}
if (order == 2){
int temp = nown[i1];
nown[i1] = nown[i2];
nown[i2] = temp;
}
if (order == 3){
int temp = nowm[i1];
nowm[i1] = nowm[i2];
nowm[i2] = temp;
}
}
}
return 0;
}