关于ACM Let the Balloon RiseC实现

#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
", maxColor);
        free(array);
    }
}

还不知道哪错。。。。。解决中郁闷。。。。

2013/12/23

问题解决了感谢CSDN的logiciel

http://bbs.csdn.net/topics/390675634

#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
", maxColor);
    free(array);
  }
}
原文地址:https://www.cnblogs.com/songyy/p/3486149.html