首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C++ >

关于ACM Let the Balloon Rise有关问题

2014-04-22 
关于ACM Let the Balloon Rise问题求助#include #include int main(){int num, i, k,

关于ACM Let the Balloon Rise问题求助

#include <stdio.h>
#include <string.h>

int main(){
int num, i, k, j, max, times;
char **array;
char maxColor[21];
while (scanf("%d", &num) != EOF && num != 0)
{
getchar();

array = (char **)malloc(sizeof(char*)*num);
for (i = 0; i < num; i++)
{
array[i] = (char *)malloc(sizeof(char)* 21);
gets(array[i]);
}
max = 0;
times = 0;

for (k = 0; k < num; k++)
{
for (j = 0; j < num; j++)
{
if (strcmp(array[k], array[j]) == 0)
{
times++;
}
}
if (times > max)
{
max = times;
strcpy(maxColor, array[k]);
}
}
printf("%s\n", maxColor);
free(array);
}
}


求解不知道哪错了,显示Wrong Answer
[解决办法]
少了个头文件
#include <stdlib.h>

[解决办法]
如下修改AC.
#include <stdio.h>
#include <string.h>
#include <stdlib.h> //加

int main(){
  int num, i, k, j, max, times;
  char **array;
  char maxColor[21];
  while (scanf("%d", &num) != EOF && num != 0)
  {
    getchar();

    array = (char **)malloc(sizeof(char*)*num);
    for (i = 0; i < num; i++)
    {
      array[i] = (char *)malloc(sizeof(char)* 21);
      gets(array[i]);
    }
    max = 0;
    //删times = 0;

    for (k = 0; k < num; k++)
    {
      times = 0;//加
      for (j = 0; j < num; j++)
      {
        if (strcmp(array[k], array[j]) == 0)
        {
          times++;
        }
      }
      if (times > max)
      {
        max = times;
        strcpy(maxColor, array[k]);
      }
    }
    printf("%s\n", maxColor);
    free(array);
  }
}

热点排行