题目:有一个已经排好序的数组。现输入一个数,要求按原来的规律将它插入数组中。
程序分析:首先判断此数是否大于最后一个数,然后再考虑插入中间的数的情况,插入后此元素之后的数,依次后移一个位置。
程序源代码:
实例(Python 2.0+)
#!/usr/bin/python# -*- coding: UTF-8 -*-if__name__ == '__main__': # 方法一 : 0 作为加入数字的占位符 a = [1,4,6,9,13,16,19,28,40,100,0] print('原始列表:') foriinrange(len(a)): print(a[i]) number = int(input("\n插入一个数字:\n")) end = a[9] ifnumber > end: a[10] = number else: foriinrange(10): ifa[i] > number: temp1 = a[i] a[i] = number forjinrange(i + 1,11): temp2 = a[j] a[j] = temp1 temp1 = temp2 break print('排序后列表:') foriinrange(11): print(a[i])
以上实例输出结果为:
原始列表:
1
4
6
9
13
16
19
28
40
100
0
插入一个数字:
7
排序后列表:
1
4
6
7
9
13
16
19
28
40
100