鱼C论坛

 找回密码
 立即注册
楼主: zwj.123

[已解决]在身份证中提取出生日期并排序,球球大佬帮忙看看为啥使用的qsort出现segemetionfault

[复制链接]
 楼主| 发表于 2022-11-28 20:47:25 | 显示全部楼层
zhangjinxuan 发表于 2022-11-28 20:42
我明天再试试吧,我都晕了

我也是,呜呜呜,晕了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 20:47:34 | 显示全部楼层
身份证18位
声明字符串必须是19个字符
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 20:48:40 | 显示全部楼层
jhq999 发表于 2022-11-28 20:47
身份证18位
声明字符串必须是19个字符

我怎么没想到!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 20:54:03 | 显示全部楼层
zwj.123 发表于 2022-11-28 20:47
我也是,呜呜呜,晕了

我开了开电脑,我真的没问题,你说你的排序方法是怎样的?从大到小还是神马?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-28 20:54:32 | 显示全部楼层
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int compare(const void *e1,const void *e2)
{
   return *(int*)e1-*(int*)e2;
}
//身份证排序
int main()
{
    char a[4][19]={'\0'};
    int b[3]={'\0'};
    int i,j,k;
 //输入
    for(i=0;i<3;i++)
    {
        scanf("%s",a[i]);
    }
    //提取出生日期

    //打印出生日期
    for(i=0;i<3;i++)
    {
        strcpy(a[3],a[i]+6);
        a[3][8]='\0';
        printf("%s\n",a[3]);
        sscanf(a[3],"%d",&b[i]);
    }
//排序
    qsort(b,3,sizeof(int),compare);

    for(i=0;i<3;i++)
    {
     printf("%d\n",b[i]);
    }

    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 21:04:10 | 显示全部楼层
zhangjinxuan 发表于 2022-11-28 20:54
我开了开电脑,我真的没问题,你说你的排序方法是怎样的?从大到小还是神马?

从小到大吧
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 21:08:48 | 显示全部楼层

我也是呜呜呜
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 21:23:29 | 显示全部楼层
zhangjinxuan 发表于 2022-11-28 20:54
我开了开电脑,我真的没问题,你说你的排序方法是怎样的?从大到小还是神马?

好家伙,这两个编译器简直了,有点毒
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-11-28 21:24:27 | 显示全部楼层
zhangjinxuan 发表于 2022-11-28 20:54
我开了开电脑,我真的没问题,你说你的排序方法是怎样的?从大到小还是神马?

我下次换着来算了,呜呜呜,头都晕了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-29 09:33:25 | 显示全部楼层
zwj.123 发表于 2022-11-28 21:24
我下次换着来算了,呜呜呜,头都晕了

可以给一个你输入出错的数据吗?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-29 09:43:10 | 显示全部楼层
本帖最后由 zhangjinxuan 于 2022-11-29 09:55 编辑
zwj.123 发表于 2022-11-28 20:47
我也是,呜呜呜,晕了


用这个就没事了,干嘛要用二维?
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int compare(const void *e1,const void *e2)
{
   return strcmp((char*)e1,(char*)e2);;
}
//身份证排序
int main()
{
    char a[3][18]={'\0'},b[3][18]={'\0'};
    int i,j,k;
 //输入
    for(i=0;i<3;i++)
    {
        scanf("%s",a[i]);
    }
    //提取出生日期
 for(j=0;j<3;j++)
   {
    for(i=6,k=0;i<14,k<8;i++,k++)
    {
        b[j][k]=a[j][i];
    }
    }
    //打印出生日期
    for(i=0;i<3;i++)
    {

        printf("%s\n",b[i]);
    }
//排序
    qsort(b,3,sizeof(b[0]),compare);
    
    for(i=0;i<3;i++)
    {
     printf("%s\n",b[i]);
    }

    return 0;
}

还有,你输入的数据是什么,输出了什么,你预期输出什么,我很好奇
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-11-29 09:52:06 | 显示全部楼层
zwj.123 发表于 2022-11-28 20:38
呜呜呜,为啥,我换个编译器试试

我这边完全没有问题
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-1 19:41:08 | 显示全部楼层
zhangjinxuan 发表于 2022-11-29 09:33
可以给一个你输入出错的数据吗?

抱歉,这几天在上课,没注意看消息
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-1 19:42:00 | 显示全部楼层
zwj.123 发表于 2022-12-1 19:41
抱歉,这几天在上课,没注意看消息


没事

那么,你输入的数据是什么,输出了什么,你预期输出什么?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-1 19:52:56 | 显示全部楼层
zhangjinxuan 发表于 2022-11-29 09:43
用这个就没事了,干嘛要用二维?

1.身份证生日排序:用原本的一级指针没有问题
                           ,用二维指针出现了segemetion fault
2.字符串排序:这个嘛,我用一级指针,输入zhang,wang,li
                                                目的是从小到大排序 输出的li,zhang,wang
                                   用二维指针就正常了
我用的MobaXterm,编译的
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int compare(const void *e1,const void *e2)
{
 //    return strcmp(*(char**)e1,*(char**)e2);
    return strcmp((char*)e1,(char*)e2);
}
int main()
{
    char**a;
    char ch[100];
    int n=3,i,j;
 //创建二维指针                   
    a=(char**)malloc(n*sizeof(char*));
    if(a==NULL)
    {
        free(a);
        exit(1);
    }
    for(i=0;i<n;i++)
    {
        a[i]=(char*)malloc(100*sizeof(char));
        if(a[i]==NULL)
        {
            for( j=0;j<=i;j++)
                free(a[j]);
        }
    }
    //输入
    for(i=0;i<n;i++)
    {
        scanf("%s",a[i]);
    }
   // 排序
    qsort(a,n,sizeof(a[0]),compare);
    //打印
    for(i=0;i<n-1;i++)
    {
        printf("%s\n",a[i]);
    }
    
    printf("%s",a[i]);
    printf("\n");
    // free掉
    for(i=0;i<n;i++)
    {
        free(a[i]);
    }
    free(a);
    return 0;
}
 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-1 19:56:53 | 显示全部楼层
zwj.123 发表于 2022-12-1 19:52
1.身份证生日排序:用原本的一级指针没有问题
                           ,用二维指针出现了segemetio ...

我测试的结果却是不管是二维还是一维,输出的总是:
li
zhang
wang
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-1 20:01:50 | 显示全部楼层
zwj.123 发表于 2022-12-1 19:52
1.身份证生日排序:用原本的一级指针没有问题
                           ,用二维指针出现了segemetio ...

不太建议在不是字符串常量的时候用指针,平常我都是搞二维数组的
试试这个:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int compare(const void *e1, const void *e2) {
    return strcmp((char*)e1, (char*)e2);
}
int main() {
        char a[3][1001] = {'\0'};
        for (int i = 0; i < 3; ++i)
                scanf("%s", &a[i]);
    qsort(a, 3, sizeof(a[0]), compare);
    for (int i = 0; i < 3; ++i)
            printf("%s\n", a[i]);
    return 0;
}
 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-1 20:02:04 | 显示全部楼层
zhangjinxuan 发表于 2022-12-1 19:56
我测试的结果却是不管是二维还是一维,输出的总是:

应该是li
wang
zhang
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-12-1 20:02:42 | 显示全部楼层
zwj.123 发表于 2022-12-1 20:02
应该是li
wang
zhang

对啊,正确的应该是 li wang zhang,但是你的代码输出的好像是 li zhang wang
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-12-1 20:02:57 | 显示全部楼层
zwj.123 发表于 2022-12-1 20:02
应该是li
wang
zhang

要不加个联系方式吧,我解释解释,这个不能发图片,太难了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-12-26 09:56

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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