You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
79 lines
1.4 KiB
79 lines
1.4 KiB
#include <iostream>
|
|
/*
|
|
测试用例 13 13
|
|
#############
|
|
#GG.GGG#GGG.#
|
|
###.#G#G#G#G#
|
|
#.......#..G#
|
|
#G#.###.#G#G#
|
|
#GG.GGG.#.GG#
|
|
#G#.#G#.#.###
|
|
##G...G.....#
|
|
#G#.#G###.#G#
|
|
#...G#GGG.GG#
|
|
#G#.#G#G#.#G#
|
|
#GG.GGG#G.GG#
|
|
#############
|
|
*/
|
|
using namespace std;
|
|
int main() {
|
|
char a[20][21]; //假设地图大小不超过20*20
|
|
int i,j,sum,map=0,p,q,x,y,n,m;
|
|
cin>>n>>m; //输入行数和列数及各行字符
|
|
for(i=0; i<n; i++)
|
|
for(j=0; j<m; j++)
|
|
cin>>a[i][j];
|
|
for(i=0; i<n; i++) { //两重循环枚举地图每一点
|
|
for(j=0; j<m; j++) {
|
|
if(a[i][j]=='.') { //判断是否为平地
|
|
sum=0; //计数可以消灭的敌人数
|
|
|
|
//向上统计可以消灭的敌人数
|
|
x=i;
|
|
y=j;
|
|
while(a[x][y]!='#') { //判断是否为墙,不为墙则继续
|
|
if(a[x][y]=='G') //当前是敌人,则计数
|
|
sum++;
|
|
x--; //继续向上计数
|
|
}
|
|
|
|
//向下统计可以消灭的敌人数
|
|
x=i;
|
|
y=j;
|
|
while(a[x][y]!='#') {
|
|
if(a[x][y]=='G')
|
|
sum++;
|
|
x++; //继续向下计数
|
|
}
|
|
|
|
//向左统计可以消灭的敌人数
|
|
x=i;
|
|
y=j;
|
|
while(a[x][y]!='#') {
|
|
if(a[x][y]=='G')
|
|
sum++;
|
|
y--; //继续向左计数
|
|
}
|
|
|
|
//向右统计可以消灭的敌人数
|
|
x=i;
|
|
y=j;
|
|
while(a[x][y]!='#') {
|
|
if(a[x][y]=='G')
|
|
sum++;
|
|
y++; //继续向右计数
|
|
}
|
|
//更新map的值
|
|
if(sum>map) {
|
|
map=sum;
|
|
p=i; //p、q记录坐标值
|
|
q=j;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
cout<<"将炸弹放置在("<<p<<","<<q<<")处,最多可以消灭"<<map<<"个敌人!"<<endl;
|
|
return 0;
|
|
}
|
|
|