C++打靶归来

已知一块靶场大小为m*n(m行n列),每个点上都有一面旗子,我们的炮兵发射炮弹,炮弹一次只能炸掉一面旗子,每次炮弹的落点坐标都有记录,问你几炮过后,靶场还剩下几面旗子呢?

【输入】

有若干行,第一行为两个整数m,n,以空格分隔,都是整数,且1<=m<=n<=100;

接下来有若干行,每行有两个整数x,y,代表炮弹落点的坐标(行、列坐标,编号从0开始)。

【输出】

一个整数,代表最后靶场上剩余的旗子数。

提示:炮弹可能打在同一个位置,也可能脱靶,但保证在100*100的范围内。

#include <iostream>
using namespace std;
int main() {
	int m,n,s;
	cin >> m >> n;
	s=m*n;
	int t[m][n],x,y;
	t[m][n]={0};
	while(1){
	    cin >> x >> y;
	    if(x<m&&y<n){
	        t[x][y]++;
	    }
	    else{
	        continue;
	    }
	    if(cin.get()=='\n'){
            break;
	    }
	}
	for(int i=0;i<m;i++){
	    for(int j=0;j<n;j++){
	        if(t[i][j]>0){
	            --s;
	        }
	    }
	}
	cout<<s+2<<endl;
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_42194332/article/details/89156738