wuli_Susu 2018-01-22 13:41 采纳率: 100%
浏览 1043
已采纳

ZOJ的1002题,我试了很多输入但找不到错在哪里,在OJ上是WA,拜托大神们帮我看看

题目地址
#include
using namespace std;

char* CreateMap(char map[][4],int n) {
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
cin >> map[i][j];
}
}
return *map;
}
void PrintMap(char map[][4], int n) {
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
cout<< map[i][j];
}
cout << endl;
}
}

bool Judge(char map[][4], int n,int i,int j) {
char m = map[i][j];
if (m == 'X' || m == 'O') return false;
if (m == '.') {
int p, q;
bool flag = true;
for (p = j-1; p >=0; p--) {
if (map[i][p] == 'O')flag = false;
if (map[i][p] == 'X')break;
}
for (p = j + 1; p < n; p++) {
if (map[i][p] == 'O')flag = false;
if (map[i][p] == 'X')break;
}
for (q = i - 1; q >= 0; q--) {
if (map[q][j] == 'O')flag = false;
if (map[q][j] == 'X')break;
}
for (q = i + 1; q < n; q++) {
if (map[q][j] == 'O')flag = false;
if (map[q][j] == 'X')break;
}
return flag;
}
}

int SearchMap(char map[][4],int n,int i,int j) {
bool flag;
int count = 0;
int p, q;
p = i;
for (q = j; q < n; q++) {
flag = Judge(map, n, p, q);
if (flag) {
map[p][q] = 'O';count++;
}
}
for (p = i + 1; p < n; p++) {
for (q = 0; q < n; q++) {
flag = Judge(map, n, p, q);
if (flag) {
map[p][q] = 'O'; count++;
}
}
}
return count;
}
void ReSet(char map[][4], int n) {
for (int i = 0; i < n; i++) {
for (int j = 0; j < n; j++) {
if (map[i][j] == 'O')map[i][j] = '.';
}
}
}

int MaxSearch(char map[][4], int n) {
int count = 0;
int j,h,k;
int i = 0;
for (j = 0; j < n; j++) {
int count2 = SearchMap(map, n, i, j);
ReSet(map, n);
if (count2 > count) {
count = count2; h = i; k = j;
}
}
return count;
}

int main() {
int n;
while (cin>>n&&n!=0) {
char map[4][4];
CreateMap(map, n);
int count = MaxSearch(map, n);
cout << count << endl;
}
return 0;
}

  • 写回答

9条回答 默认 最新

  • hany2008 2018-01-22 16:04
    关注

    代码其它部门没有问题

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(8条)

报告相同问题?

悬赏问题

  • ¥15 易盾点选的cb参数怎么解啊
  • ¥15 MATLAB运行显示错误,如何解决?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容
  • ¥15 UE5#if WITH_EDITOR导致打包的功能不可用
  • ¥15 关于#stm32#的问题:CANOpen的PDO同步传输问题
  • ¥20 yolov5自定义Prune报错,如何解决?
  • ¥15 电磁场的matlab仿真
  • ¥15 mars2d在vue3中的引入问题
  • ¥50 h5唤醒支付宝并跳转至向小荷包转账界面