八戒253 发表于 2021-6-5 15:48:06

查 BUG 不知道自己哪里出错了 回帖鱼币

{:10_256:}



/*集体照*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define LEN 10000
struct ren
{
        char name;
        int gao;
};
//由大到小排序
int my_cmp(const void *a,const void *b)
{
        struct ren *aa = (struct ren *)a;
        struct ren *bb = (struct ren *)b;
        if(aa->gao !=bb->gao)
                return bb->gao - aa->gao;//降序
        else
                return strcmp(aa->name,bb->name);//升序
}
int main(void)
{
        int N,K;
        int i,j,k,m,n,mid;
        int sign = 1;
        struct ren a,b;
        scanf("%d %d",&N,&K);
        for(i=0;i<N;i++)
        {
                scanf("%s %d",&a.name,&a.gao);
                getchar();
        }
        qsort(a,N,sizeof(a),my_cmp);
        m = N/K;//其他排的人数
        n = m+N%K;//最后一排的人数
        char p;//存放最后的结果
        for(i=0;i<K;i++)
        {
                if(i==0) mid = n/2;
                else mid = m/2;
                for(k=0,j=0;;k++)
                {
                        if(i==0)
                                if(k == n) break;
                        else if(k == m) break;
                        mid = mid+sign*k;
                        strcpy(p,a.name);
                        sign = -sign;
                }
        }
        //打印输出
        for(i=0;i<K;i++)
        {
                for(j=0;;j++)
                {
                        if(i==0)
                        {
                                if(j==n) break;
                        }
                        else
                        if(j == m) break;
                        printf(j==0?"%s":" %s",p);
                }
                putchar('\n');
        }
        return 0;
       
}

帮忙查一下BUG

1012327963 发表于 2021-6-5 17:16:22

我看看哈,说不定有人在解决了ing

八戒253 发表于 2021-6-6 15:05:16

好心人们,你们在哪??
{:10_297:}

人造人 发表于 2021-6-7 12:16:46

没有看懂题意,我估计这个程序就只能实现这一个输入样例
$ ./main
10 3
Tom 188
Mike 170
Eva 168
Tim 160
Joe 190
Ann 168
Bob 175
Nick 186
Amy 160
John 159
Bob Tom Joe Nick
Ann Mike Eva
Tim Amy John


下面这个应该不是你想要的
$ ./main
7 3
Tom 188
Mike 170
Eva 168
Tim 160
Joe 190
Ann 168
Bob 175
Tom Joe Bob
Ann Mike
Tim Eva


/*集体照*/
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define LEN 10000
struct ren
{
    char name;
    int gao;
};
//由大到小排序
int my_cmp(const void *a,const void *b)
{
    struct ren *aa = (struct ren *)a;
    struct ren *bb = (struct ren *)b;
    if(aa->gao !=bb->gao)
      return bb->gao - aa->gao;//降序
    else
      return strcmp(aa->name,bb->name);//升序
}
int main(void)
{
    int N,K;
    int i,j,k,m,n,mid;
    int sign;
    struct ren a = {0};
    scanf("%d %d",&N,&K);
    for(i=0;i<N;i++)
    {
      scanf("%s %d",a.name,&a.gao);
      getchar();
    }
    qsort(a,N,sizeof(a),my_cmp);
    m = N/K;//其他排的人数
    n = m+N%K;//最后一排的人数
    char p;//存放最后的结果
    j = 0;
    for(i=0;i<K;i++)
    {
      sign = 1;
      if(i==0) mid = n/2;
      else mid = m/2;
      for(k=0;;k++)
      {
            if(i==0) {
                if(k == n) break;
            } else if(k == m) break;
            mid = mid+sign*k;
            strcpy(p,a.name);
            sign = -sign;
      }
    }
    //打印输出
    for(i=0;i<K;i++)
    {
      for(j=0;;j++)
      {
            if(i==0)
            {
                if(j==n) break;
            }
            else
                if(j == m) break;
            printf(j==0?"%s":" %s",p);
      }
      putchar('\n');
    }
    return 0;

}

八戒253 发表于 2021-6-8 16:38:24

人造人 发表于 2021-6-7 12:16
没有看懂题意,我估计这个程序就只能实现这一个输入样例




谢谢啦,原来是 j 和 sign 的问题

懒狗李 发表于 2021-6-8 18:20:26

水一下

noah-py 发表于 2021-6-9 22:40:08

{:10_275:}

1124296523 发表于 2021-6-16 10:59:27

加油

hornwong 发表于 2021-6-16 11:34:40

{:5_95:}

ridiculum 发表于 2021-6-19 09:50:07

{:10_279:}

ridiculum 发表于 2021-6-19 09:52:53

{:10_279:}

ridiculum 发表于 2021-6-19 09:58:05

{:10_279:}

超级玛尼哄 发表于 2021-6-19 18:43:21

{:10_249:}{:10_249:}

坠星メ梦 发表于 2021-6-20 17:19:18

加油

Dragon910623 发表于 2021-6-21 13:11:32

新人来向大佬学习

moskiller 发表于 2021-6-21 14:59:34

向大佬学习

Affair 发表于 2021-6-21 21:12:51

{:10_254:}

和光同尘-32 发表于 2021-6-28 15:41:25


向大佬学习

Lexroll 发表于 2021-6-28 16:09:00

学一波

门口保安 发表于 2021-7-10 03:10:26

学一波
页: [1]
查看完整版本: 查 BUG 不知道自己哪里出错了 回帖鱼币