PTA 实验7-1-1 简化的插入排序 (15分)

本题要求编写程序,将一个给定的整数插到原本有序的整数序列中,使结果序列仍然有序。

输入格式:
输入在第一行先给出非负整数N(<10);第二行给出N个从小到大排好顺序的整数;第三行给出一个整数X。

输出格式:
在一行内输出将X插入后仍然从小到大有序的整数序列,每个数字后面有一个空格。

输入样例:
5
1 2 4 5 7
3
输出样例:
1 2 3 4 5 7

#include<stdio.h>

void fun(int *st, int n,int x);

int main(void)
{
    int n;
    scanf("%d", &n);
    int num[n+1];
    for (int i = 0; i < n;i++)
        scanf("%d", &num[i]);
    int x;
    scanf("%d", &x);
    
    fun(num, n, x);

    for (int i = 0; i < n + 1;i++)
        printf("%d ", num[i]);

    return 0;
}
void fun(int *st,int n,int x)
{
    int i;
    if(x<st[0])
    {
        for (i = n; i > 0;i--)
        {
            st[i] = st[i - 1];
        }
        st[0] = x;
    }
    else if(x>st[n-1])
            st[n] = x;
        else
        {
            for ( i = 1; i < n;i++)
            {
                if(st[i]>x&&st[i-1]<x)
                    break;
            }
            for (int j=n; j> i;j--)
            {
                st[j] = st[j - 1];
            }
            st[i] = x;
        } 
}

展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 1024 设计师: 上身试试
应支付0元
点击重新获取
扫码支付

支付成功即可阅读