【Python】华为的一道编程题
来源:互联网 发布:python脚本怎么执行 编辑:程序博客网 时间:2024/06/06 04:14
有两个序列a,b,大小都为n,序列元素的值任意整形数,无序;
要求:通过交换a,b中的元素,使[序列a元素的和]与[序列b元素的和]之间的差最小。
1. 将两序列合并为一个序列,并排序,为序列Source
2. 拿出最大元素Big,次大的元素Small
3. 在余下的序列S[:-2]继续拿出最大和最小元素,最后得到各有一个元素的得到序列small_list, large_list
4. 将Small加到max序列,将Big加大min序列,以此递归,重新计算新序列和,和大的为max,小的为min。
'''有两个序列a,b,大小都为n,序列元素的值任意整型数,无序;要求:通过交换a,b中的元素,使[序列a元素的和]与[序列b元素的和]之间的差最小。>>> a = [1,4,6,2,9], b = [5,7,3,10,8]>>>输出为 a = [2, 3, 6, 7, 10], b = [1, 4, 5, 8, 9]'''def recrs_ave(source_list): if not source_list: return([], []) else: large = source_list[-1] small = source_list[-2] small_list, large_list = recrs_ave(source_list[:-2]) if sum(small_list) <= sum(large_list): small_list.append(large) large_list.append(small) else: small_list.append(small) large_list.append(large) return((small_list, large_list))tests = [ [1,2,3,4,5,6,700,800], [10001,10000,100,90,50,1], list(range(1, 11)), [12312, 12311, 232, 210, 30, 29, 3, 2, 1, 1] ]for sorted_list in tests: #sorted_list = a.__add__(b) sorted_list.sort() print(sorted_list) l1, l2 = recrs_ave(sorted_list) print(l1, l2) print("Distance is: %d" % abs(sum(l1) - sum(l2)))
>>> ================================ RESTART ================================>>> [1, 2, 3, 4, 5, 6, 700, 800][2, 3, 6, 700] [1, 4, 5, 800]Distance is: 99[1, 50, 90, 100, 10000, 10001][50, 90, 10000] [1, 100, 10001]Distance is: 38[1, 2, 3, 4, 5, 6, 7, 8, 9, 10][2, 3, 6, 7, 10] [1, 4, 5, 8, 9]Distance is: 1[1, 1, 2, 3, 29, 30, 210, 232, 12311, 12312][1, 3, 29, 232, 12311] [1, 2, 30, 210, 12312]Distance is: 21
0 0
- 【Python】华为的一道编程题
- 一道华为编程题
- 华为的一道题
- 上海华为的一道关于指针方面的编程题
- 上海华为的一道关于指针方面的编程题
- 一道可用背包问题解的华为编程题
- 一道华为编程大赛的试题
- 一道华为的数据库题
- 华为的一道笔试题
- 华为的一道笔试题
- 华为的一道改错题的试验
- 上海华为的一道关于指针方面的编程题,大家来看看
- 上海华为的一道关于指针方面的编程题(07年)
- 20080306:上海华为的一道关于指针的编程题目
- 华为的一道编码笔试题
- 华为面试题——一道关于指针方面的编程题(C/C++)
- 插一道华为的题目,华为就爱这种题
- 一道华为上机题
- leetcode Median of Two Sorted Arrays
- 虚拟化实践:云桌面安装
- Android Shell命令dumpsys
- 理解Linux系统负荷
- Android 20140525 笔记
- 【Python】华为的一道编程题
- Robberies
- Microsoft URL Rewrite Module for IIS 7.0
- 模2除法
- WebService 设计总结
- 美国华裔科学家谈免疫系统真相!运动,心情胜过一切药品!
- 程序设计实习MOOC/第十四周编程作业/B:迷宫问题
- 林达华推荐的几本数学书
- 扩展KMP算法(Extend KMP) 学习小记 Hdu 4333 Revolving Digits