阿白| 2021-11-02 21:53 采纳率: 91.7%
浏览 41
已结题

ZZULIOJ1118:来瞅瞅我写的bug叭!

题目是这样的:
题目描述
一个非递减有序的整型数组有n个元素,给定一个整数num,将num插入该序列的适当位置,使序列仍保持非递减有序。
要求定义一个函数insert(),将整数num插入在数组a的适当位置上,函数原型如下:
int insert(int a[], int n, int num);
另外函数仍然调用以前定义过的函数PrintArr()输出数组所有元素。
输入
输入有三行。第一行是一个正整数n,n<=1000。第二行是n个整数,第三行是待插入整数num。
输出
输出非递减有序的n+1个整数,数据之间用空格隔开。输出占一行。
样例输入 Copy
5
1 2 4 5 6
3
样例输出 Copy
1 2 3 4 5 6
提示
元素之间有空格,最后一个元素后面没有空格。

我的问题在于:我的代码输出的是1 2 4 5 6 3!调试了好久了,也没办法发现自己的逻辑错误,求助!


#include<stdio.h>
int insert(int a[],int n,int num)
{
    int i;
    for(i=n-1;i>=0;i--)
    {
        if(a[i]>num)
        {
            a[i+1]=a[i];
            a[i]=num;
        }
        else
        {
            a[i+1]=num;
        }
    }
}
void printArr(int a[],int n)
{
    int i,j=1;
    for(i=0;i<=n;i++)
    {
        printf("%d",a[i]);
        if(j<=n)
            printf(" ");
        j++;
    }
}
int main()
{
    int n,num;
    scanf("%d",&n);
    int a[n+1];
    scanf("%d",&num);
    for(int i=0;i<n;i++)
    {
        scanf("%d",&a[i]);
    }
    insert(a,n,num);
    printArr(a,n);
    return 0;
}
  • 写回答

1条回答 默认 最新

  • -Undefined_ 2021-11-02 22:30
    关注
    #include<stdio.h>
    int insert(int a[],int n,int num) {
        int i,p=0;
        for(i=n-1; i>=0; i--) {
            if(a[i]<num) {
                p=i+1;
                break;
            }
        }
        return p;
    }
    void printArr(int a[],int n) {
        int i,j=1;
        for(i=0; i<=n; i++) {
            printf("%d",a[i]);
            if(j<=n)
                printf(" ");
            j++;
        }
    }
    int main() {
        int n,num,p;
        scanf("%d",&n);
        int a[n+1];
    
        for(int i=0; i<n; i++) {
            scanf("%d",&a[i]);
        }
        scanf("%d",&num);
        p=insert(a,n,num);
        for(int i=n-1;i>=p;i--){
            a[i+1]=a[i];
        }
        a[p]=num;
        printArr(a,n);
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 11月10日
  • 已采纳回答 11月2日
  • 创建了问题 11月2日

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器