ZZULIOJ:1118数列有序(数组专题)

ZZULIOJ:1118数列有序

  • 题目描述
  • 输入
  • 输出
  • 样例输入
  • 样例输出
  • 提示
  • 思路
  • 答案

题目描述

一个非递减有序的整型数组有n个元素,给定一个整数num,将num插入该序列的适当位置,使序列仍保持非递减有序。

要求定义一个函数insert(),将整数num插入在数组a的适当位置上,函数原型如下:

int insert(int a[], int n, int num);

另外函数仍然调用以前定义过的函数PrintArr()输出数组所有元素。

输入

输入有三行。第一行是一个正整数n,n<=1000。第二行是n个整数,第三行是待插入整数num。

输出

输出非递减有序的n+1个整数,数据之间用空格隔开。输出占一行。

样例输入

5
1 2 4 5 6
3

样例输出

1 2 3 4 5 6

提示

元素之间有空格,最后一个元素后面没有空格。

思路

拿着num从最后一个数组中元素比较,如果num比当前元素小,则把当前元素往后挪动一个位置,判断下一个元素。直到num比当前元素大时,将num放在当前元素后面,因为每次挪动元素的时候都将其原来的位置“腾出”了。(特别要注意num比到a[0]仍然不够大的情况,直接将num放在a[0]处)

答案

#include
void insert(int a[], int n, int num)

你可能感兴趣的:(c语言)