已知一块靶场大小为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;
}