数组-12. 简易连连看(20)

数组-12. 简易连连看(20)

时间限制

400 ms

内存限制

65536 kB

代码长度限制

8000 B

判题程序

Standard

作者

陈建海(浙江大学)

本题要求实现一个简易连连看游戏模拟程序。

给定一个2Nx2N的方阵网格游戏盘面,每个格子中放置一些符号。这些符号一定是成对出现的,同一个符号可能不止一对。程序读入玩家给出的一对位置(x1, y1)、(x2, y2),判断这两个位置上的符号是否匹配。如果匹配成功,则将两个符号消为“*”并输出消去后的盘面;否则输出“Uh-oh”。若匹配错误达到3次,则输出“Game Over”并结束游戏。或者当全部符号匹配成功,则输出“Congratulations!”,然后结束游戏。

输入格式:

输入在一行中给一个正整数N(<5)。随后2N行,每行2N个大写英文字母(其间以1个空格分隔),表示游戏盘面。盘面之后给出一个正整数K,随后K行,每行按照格式“x1 y1 x2 y2”给出一个玩家的输入。注意格子的行、列编号是从1到2N。

输出格式:

根据玩家的每一步输入,输出相应的结果。输出盘面时注意,每行字符间以1个空格分隔,行末不得有多余空格。

输入样例1:

2
I T I T
Y T I A
T A T Y
I K K T
11
1 1 1 3
4 2 4 3
3 1 4 2
2 2 1 2
3 1 2 4
4 4 3 1
2 1 3 4
3 3 1 4
4 1 2 3
2 4 3 2
1 1 2 2

输出样例1:

* T * T
Y T I A
T A T Y
I K K T
* T * T
Y T I A
T A T Y
I * * T
Uh-oh
* * * T
Y * I A
T A T Y
I * * T
Uh-oh
* * * T
Y * I A
* A T Y
I * * *
* * * T
* * I A
* A T *
I * * *
* * * *
* * I A
* A * *
I * * *
* * * *
* * * A
* A * *
* * * *
Congratulations!

输入样例2:

2
I T I T
Y T I A
T A T Y
I K K T
5
1 1 4 4
1 1 2 3
1 1 2 3
2 2 4 1
2 2 3 3

输出样例2:

Uh-oh
* T I T
Y T * A
T A T Y
I K K T
Uh-oh
Uh-oh
Game Over
#include <cstdio>
#include <iostream>
#define MAX 10
using namespace std;

void print(char ch[MAX][MAX],int N){
	int sign;
	for(int i=1;i<=2*N;++i){
		sign=0;
		for(int j=1;j<=2*N;++j){
			printf("%c",ch[i][j]);
			if(++sign<2*N){
				printf(" ");
			}
		}
		printf("\n");
	}
}

int main(){
	int N;
	scanf("%d",&N);
	char ch[MAX][MAX]={0};
	for(int i=1;i<=2*N;++i){
		for(int j=1;j<=2*N;++j){
			cin >> ch[i][j];
			//scanf("%c", &ch[i][j]);
			//用scanf导致空格和换行各种混淆
			//cin会根据对象类型进行智能赋值,不会把空格换行读入!
		}

	}
	int K;
	cin >> K;
	int sum=0;//错误次数
	int count=0;//消去次数,用次数,否则每次都去判断是否全部消去太费时
	while(K--){
		int x1,y1,x2,y2;
		scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
		if(ch[x1][y1]==ch[x2][y2]&&ch[x1][y1]!='*'&&ch[x2][y2]!='*'){
										//一开始忘了消去以后的相等是不算的!
			ch[x1][y1]=ch[x2][y2]='*';
			++count;
			if(count==2*N*N){
			cout<< "Congratulations!"<<endl;
			break;
			}
			print(ch,N);
		}
		else{
			printf("Uh-oh\n");
			++sum;
		}
		if(sum>=3){
			cout << "Game Over"<<endl;
			break;
		}
	}
	return 0;
}
时间: 2024-11-08 20:18:07

数组-12. 简易连连看(20)的相关文章

数组-12. 简易连连看

1 /* 2 * Main.c 3 * E12-数组-12. 简易连连看 4 * Created on: 2014年8月22日 5 * Author: Boomkeeper 6 ********测试通过********* 7 */ 8 9 #include <stdio.h> 10 #include <stdlib.h> 11 12 int main(void){ 13 14 int x1,y1,x2,y2; 15 int i,j,k; 16 int N;//题目中的N 17 ch

实验7-2-10 简易连连看 (20分)

本题要求实现一个简易连连看游戏模拟程序. 给定一个2的方阵网格游戏盘面,每个格子中放置一些符号.这些符号一定是成对出现的,同一个符号可能不止一对.程序读入玩家给出的一对位置(.(,判断这两个位置上的符号是否匹配.如果匹配成功,则将两个符号消为“*”并输出消去后的盘面:否则输出“Uh-oh”.若匹配错误达到3次,则输出“Game Over”并结束游戏.或者当全部符号匹配成功,则输出“Congratulations!”,然后结束游戏. 输入格式: 输入在一行中给一个正整数N(<).随后2行,每行2个

数组-06. 找出不是两个数组共有的元素(20)

1 #include<iostream> 2 using namespace std; 3 int main(){ 4 int i,j,k=0,l,a[20],b[20],c[40],m,n; 5 cin>>m; 6 for(i=0;i<m;++i) 7 cin>>a[i]; 8 cin>>n; 9 for(j=0;j<n;++j) 10 cin>>b[j]; 11 12 for(i=0;i<m;++i){ 13 for(j=0

数组 :定义一个有20个元素的数组,每一个元素的取值范围是[30 ,70],求他们的和

   //定义一个有20个元素的数组,每一个元素的取值范围是[30 ,70],求他们的和     int a[20] = {0};     int sum = 0;     for (int i = 0; i < 20; i++) {         a[i] = arc4random()%(70 - 30 + 1) + 30;         printf("%d ",a[i]);         sum += a[i];     }       printf("\n

实验7-1-4-一维数组 找出不是两个数组共有的元素 (20 分)

给定两个整型数组,本题要求找出不是两者共有的元素. 输入格式: 输入分别在两行中给出两个整型数组,每行先给出正整数N(≤),随后是N个整数,其间以空格分隔. 输出格式: 在一行中按照数字给出的顺序输出不是两数组共有的元素,数字间以空格分隔,但行末不得有多余的空格.题目保证至少存在一个这样的数字.同一数字不重复输出. 输入样例: 10 3 -5 2 8 0 3 5 -15 9 100 11 6 4 8 2 6 -5 9 0 100 8 1 输出样例: 3 5 -15 6 4 1 1 #includ

数组-13. 螺旋方阵(20)

所谓“螺旋方阵”,是指对任意给定的N,将1到N*N的数字从左上角第1个格子开始,按顺时针螺旋方向顺序填入NxN的方阵里.本题要求构造这样的螺旋方阵. 输入格式: 输入在一行中给出一个正整数N(<10). 输出格式: 输出NxN的螺旋方阵.每行N个数字,每个数字占3位. 输入样例: 5 输出样例: 1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 1 #include <iostream> 2 #includ

20.10 for循环 20.11/20.12 while循环 20.13 break跳出循环 20.14 continue结束本次循环 20.15 exit退出整个脚本

20.10 for循环 ?语法:for 变量名 in 条件; do -; done ? 案例1 1+2+3..+100的和 #!/bin/bash sum=0 for i in `seq 1 100` // seq 1到100个数字 do sum=$[$sum+$i] echo $i done echo $sum sum 第一次作为变量的时候,是0:当进入for循环里面的时候,每运算一次,sum变量就会改变一次,直至$i 结束:最后输出结果 $sum ? 案例2 文件列表循环 #!/bin/ba

20.10 for循环 20.11/20.12 while循环 20.13 break跳出循环 20

20.10 for循环语法:for 变量名 in 条件; do -; done案例1#!/bin/bashsum=0for i in seq 1 100do? ? sum=$[$sum+$i]? ? echo $idoneecho $sum文件列表循环#!/bin/bashcd /etc/for a in ls /etc/do? ? if [ -d $a ]? ? then? ?? ? ls -d $a? ? fidone 20.11/20.12 while循环语法 while 条件; do -

2019.12.12 简易闯塔游戏

/** * ChuangTaGame.java * com.oracle.array * * Function: TODO  * *   ver     date        author * ────────────────────────────────── *      2019年12月9日   17671 * * Copyright (c) 2019, TNT All Rights Reserved.*/ package com.oracle.array; import java.ut