题解 | #有序序列插入一个数#

有序序列插入一个数

http://www.nowcoder.com/practice/74486aec6fe14d44b509efabf265ee66

#include <stdio.h>

int main() { int n = 0; int arr[51] = {0}; int i = 0; int x = 0; int j = 0;

scanf("%d", &n);
for (i=0; i<n; i++)
{
    scanf("%d", &arr[i]);
}

scanf("%d", &x);
if (n == 1)
{
    if (x > arr[0])
    {
        int tmp = x;
        x = arr[0];
        arr[0] = tmp;
    }
    printf("%d %d", x, arr[0]);
}
else{
for (i=0; i<n; i++)
{
    if ((arr[i] >= x && x >= arr[i-1]&& i!=0)||(arr[0]>x&&i==0))
    {
        int a = 0;
        int tmp = arr[i];
        arr[i] = x;
        for (j=i+1; j<n+1; j++)
        {
            a = arr[j];
            arr[j] = tmp;
            tmp = a;
        }
        break;
    }
    else if(x>arr[n-1] && i == n-1)
        arr[i+1] = x;
}
for (i=0; i<n+1; i++)
    printf("%d ",arr[i]);
}
return 0;

}

全部评论

相关推荐

10-15 09:13
已编辑
天津大学 soc前端设计
点赞 评论 收藏
分享
无情咸鱼王的秋招日记之薛定谔的Offer:好拒信,偷了,希望有机会用到
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务