鱼C论坛

 找回密码
 立即注册
查看: 3115|回复: 6

[已解决]c语言 通讯录排序问题

[复制链接]
发表于 2018-11-29 14:06:23 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
通信录排序:通讯录的结构记录包括姓名、生日、电话号码,其中生日又包括年、月、日这三项。定义一个嵌套的结构类型,输入n(n<10)个联系人的信息,再按他们的年龄从大到小的顺序依次输出信息
#include <stdio.h>
struct contact {
        int birth;
        char name[20];
        char tel[20];
}c1[20],t;


int main(void) {
       
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<=n;i++){
                scanf("%s%d%s",c1[i].name,&c1.birth,c1[i].tel);
        }
        for(i=0;i<n-1;i++){
                index=i;
                for(j=0;j<n-1;j++)
                if(c1[j].birth>c1[index].birth)
                index=j;
                t=c1[j];c1[j]=c1[index];c1[index]=t;
        }
        for(i=0;i<n;i++)
         printf("%s %d %s \n",c1[i].name,c1[i].birth,c1[i].tel);
        return 0;
}
最佳答案
2018-11-29 18:43:41
#include <stdio.h>
struct contact {
        int birth;
        char name[20];
        char tel[20];
}c1[20],t;


int main(void) {
        
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<=n;i++){
                scanf("%s%d%s",c1[i].name,&c1.birth,c1[i].tel);   //错误在于你写的c1.birth改成c1[i].birth
        }
        for(i=0;i<n-1;i++){
                index=i;
                for(j=0;j<n-1;j++)
                if(c1[j].birth>c1[index].birth)
                index=j;
                t=c1[j];c1[j]=c1[index];c1[index]=t;
        }
        for(i=0;i<n;i++)
         printf("%s %d %s \n",c1[i].name,c1[i].birth,c1[i].tel);
        return 0;
}
捕获.PNG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-11-29 14:07:33 | 显示全部楼层
实在想不通了,救救我吧大神们
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-29 15:03:52 | 显示全部楼层
本帖最后由 rencaixiaomeng 于 2018-11-29 15:05 编辑

#include <stdio.h>
struct contact {
        int birth;
        char name[20];
        char tel[20];
}c1[20],t;


int main(void) {
        
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<=n;i++){
                scanf("%s%d%s",c1[i].name,&c1.birth,c1[i].tel); //&c1.birth改成&c1[i].birth
        }
        for(i=0;i<n-1;i++){
                index=i;
                for(j=0;j<n-1;j++)
                if(c1[j].birth>c1[index].birth)
                index=j;
                t=c1[j];c1[j]=c1[index];c1[index]=t;
        }
        for(i=0;i<n;i++)
         printf("%s %d %s \n",c1[i].name,c1[i].birth,c1[i].tel);
        return 0;
}

你的排序也有问题,先自己改改看吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-29 17:56:12 | 显示全部楼层
#include <stdio.h>
struct contact {
        int birth;
        char name[20];
        char tel[20];
}c1[20],t;


int main() {
        
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<n;i++){
            scanf("%s%d%s",&c1[i].name,&c1[i].birth,&c1[i].tel);  //c1.birth错误, c1是个有长度的结构体,加上[i]
        }
        for(i=0;i<n;i++)     //下面是还原你的排序,你的太乱了,不一一纠错了
                {
            for(j=i+1;j<=n;j++)
            {
                                if(c1[j].birth>c1[i].birth)
                            {
                                    t=c1[j];
                                        c1[j]=c1[i];
                                        c1[i]=t;
                                }
                        }
                printf("%s %d %s \n",c1[i].name,c1[i].birth,c1[i].tel);       
        }
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-29 18:43:41 | 显示全部楼层    本楼为最佳答案   
#include <stdio.h>
struct contact {
        int birth;
        char name[20];
        char tel[20];
}c1[20],t;


int main(void) {
        
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<=n;i++){
                scanf("%s%d%s",c1[i].name,&c1.birth,c1[i].tel);   //错误在于你写的c1.birth改成c1[i].birth
        }
        for(i=0;i<n-1;i++){
                index=i;
                for(j=0;j<n-1;j++)
                if(c1[j].birth>c1[index].birth)
                index=j;
                t=c1[j];c1[j]=c1[index];c1[index]=t;
        }
        for(i=0;i<n;i++)
         printf("%s %d %s \n",c1[i].name,c1[i].birth,c1[i].tel);
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-3 17:57:19 | 显示全部楼层
#include <stdio.h>
struct birth {
        int year,mon,day;
};
struct contact {
        struct birth b;
        char name[10];
        char tel[15];
};



int main(void) {
        struct contact c1[20],t;
        struct birth ;
        int i,n,j,index;
        scanf("%d",&n);
        for(i=0;i<n;i++){
                scanf("%s %d %d %d %s",c1[i].name,&c1[i].b.year,&c1[i].b.mon,&c1[i].b.day,c1[i].tel);
        }
        for(i=0;i<n-1;i++)
        {
                index=i;
                for(j=i+1;j<n;j++){
                                if(c1[j].b.year<c1[index].b.year)
                       {
                                index=j;
                   }
                else if(c1[j].b.year==c1[index].b.year)
                {
                        if(c1[j].b.mon<c1[index].b.mon)
                        {
                                index=j;
                        }
                        else if(c1[j].b.mon==c1[index].b.mon)
                        {
                                if(c1[j].b.day<c1[index].b.day)
                                {
                                        index=j;
                                }
                               
                        }
                }

        }
                t=c1[index];c1[index]=c1[i];c1[i]=t;
       
                }       


        for(i=0;i<n;i++){
                 printf("%s\t",c1[i].name);
                  printf(" %d%d%d\t",c1[i].b.year,c1[i].b.mon,c1[i].b.day);
                   printf("%s\n",c1[i].tel);
        }
       
        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-12-3 17:59:43 | 显示全部楼层
我最后输出的0没有了,好奇怪
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-30 20:40

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表