别别别啊 2023-12-07 18:45 采纳率: 100%
浏览 6
已结题

c语言:让我水点文字不被发现

调试显示Access violation


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

void jiuming(char p[][12], int n)
{
    char c;
    int i;
    for(i=0;i<n;i++)
    {
        scanf("%s",p[i]);
        c=getchar();
    }
}
void yaowan(char p1[][12],char p2[][12],int n1,int n2)
{
    int i,j,k;
    int n;
    n=n1+n2;
    strcat(p1[30],p2[10]);
    
    for(i=0;i<n-1;i++)
    {
        k=i;
        for(j=i+1;j<n;j++)
        {
            if(strcmp(p1[k],p1[j])>0)
                k=j;
            if(k-i)
        {
            strcpy(p1[i],p1[k]);
        }
        }
        
    }
}



int main(void)
{
    char namelist1[30][12],namelist2[10][12];
    char c;
    int n1,n2;
    int i;
    scanf("%d",&n1);
    c=getchar();
    jiuming(namelist1,n1);
    c=getchar();
    scanf("%d",&n2);
    c=getchar();
    jiuming(namelist2,n2);
    yaowan(namelist1,namelist2,n1,n2);
    for(i=0;i<n1+n2;i++)
    {
        if(i==0)
        {
        if(strcmp(namelist1[i],namelist1[i+1]))
            printf("%s",namelist1[i]);
        }
        else
        {
        if(strcmp(namelist1[i],namelist1[i+1]))
            printf(" %s",namelist1[i]);
        }

    }
    return 0;

}

样例输入是:
6 jixiang lihua lihua lijian wanger zhanglin
6 chenming lihua lijian liutian zhouqi zhouqi

  • 写回答

6条回答 默认 最新

  • 专家-赤兔[在线] 全栈领域优质创作者 2023-12-07 18:45
    关注

    引自强大而免费的微信小程序:皆我百晓生

    在你的代码中,出现Access violation的问题是因为你在使用strcat函数时没有正确传入参数。你将p1[30]和p2[10]作为参数传给strcat函数,但是数组下标应该从0开始,所以应该是p1[29]和p2[9]。另外,你在比较字符串是否相等时,使用了strcmp函数,但是你没有将返回值与0进行比较,应该是strcmp(namelist1[i], namelist1[i+1])==0。下面是修改后的代码:

    #include<stdio.h>
    #include<string.h>
    
    void jiuming(char p[][12], int n)
    {
        for(int i=0; i<n; i++)
        {
            scanf("%s", p[i]);
        }
    }
    
    void yaowan(char p1[][12], char p2[][12], int n1, int n2)
    {
        int i, j, k;
        int n = n1 + n2;
    
        for(i=n1, j=0; i<n; i++, j++)
        {
            strcpy(p1[i], p2[j]);
        }
    
        for(i=0; i<n; i++)
        {
            k=i;
            for(j=i+1; j<n; j++)
            {
                if(strcmp(p1[k], p1[j])>0)
                    k=j;
            }
            if(k!=i)
            {
                char temp[12];
                strcpy(temp, p1[i]);
                strcpy(p1[i], p1[k]);
                strcpy(p1[k], temp);
            }
        }
    }
    
    int main(void)
    {
        char namelist1[30][12], namelist2[10][12];
        int n1, n2;
        scanf("%d", &n1);
        jiuming(namelist1, n1);
        scanf("%d", &n2);
        jiuming(namelist2, n2);
        yaowan(namelist1, namelist2, n1, n2);
        
        printf("%s", namelist1[0]);
        for(int i=1; i<n1+n2; i++)
        {
            if(strcmp(namelist1[i], namelist1[i-1])!=0)
            {
                printf(" %s", namelist1[i]);
            }
        }
        
        return 0;
    }
    

    这样修改后的代码应该能够正确地合并两个按字典顺序排序的名字登记表,并删除重复出现的名字,使得每个名字在登记表中只出现一次,并输出名字登记表内容。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(5条)

报告相同问题?

问题事件

  • 系统已结题 12月15日
  • 已采纳回答 12月7日
  • 修改了问题 12月7日
  • 创建了问题 12月7日

悬赏问题

  • ¥15 微信小程序 用oss下载 aliyun-oss-sdk-6.18.0.min client报错
  • ¥15 ArcGIS批量裁剪
  • ¥15 labview程序设计
  • ¥15 为什么在配置Linux系统的时候执行脚本总是出现E: Failed to fetch http:L/cn.archive.ubuntu.com
  • ¥15 Cloudreve保存用户组存储空间大小时报错
  • ¥15 伪标签为什么不能作为弱监督语义分割的结果?
  • ¥15 编一个判断一个区间范围内的数字的个位数的立方和是否等于其本身的程序在输入第1组数据后卡住了(语言-c语言)
  • ¥15 Mac版Fiddler Everywhere4.0.1提示强制更新
  • ¥15 android 集成sentry上报时报错。
  • ¥15 抖音看过的视频,缓存在哪个文件