python阿里巴巴面试题_两道阿里python面试题与参考答案解析

题目1:有一个数组a,要求写一个方法,将这个数组拆分为两个子数组,要求两个子数组内的变量之和尽可能接近:

# -*- coding:utf-8 -*-

import random

import itertools

#t_list = [1,5,6,7]

length = input('请输入要产生的随机数个数:')#可以自己创建数组也可以随机生成

t_list = []#保存原始数据

t = int(length)

for x in range(t):

t_list.append(random.randint(1, 1000))#支持负数,如要测试负数,数据范围改一下即可

medium = sum(t_list)/2#中值,作为判断依据

print(t_list)#打印原始数组

print(medium)#打印中值

tuple_temp = ()

abs_medium_tuple_sum_temp = 1000000 #该数据要大于随机值的medium

for k in range(1,t,1): #遍历所有的组合情况,找到离medium最接近的组合

for i in itertools.combinations(t_list,k):

print(i)

tuple_sum = sum(i)

abs_medium_tuple_sum = abs(medium-tuple_sum)

print("abs_medium_tuple_sum:"+str(abs_medium_tuple_sum))

if abs_medium_tuple_sum_temp >= abs_medium_tuple_sum:

abs_medium_tuple_sum_temp = abs_medium_tuple_sum

print("abs_medium_tuple_sum_temp:"+str(abs_medium_tuple_sum_temp))

tuple_temp = i

print("tuple_temp:")

print(tuple_temp)

list_a = list(tuple_temp)

t_list_temp = t_list

for m in tuple_temp:#将选出来的组合的元素从原数组中剥离

t_list_temp.remove(m)

list_b = t_list_temp

#原始数据

print(t_list)

print("第一个list:")

print(list_a)

print("第一个list的和为:"+str(sum(list_a)))

print("第二个list:")

print(list_b)

print("第二个list的和为:"+str(sum(list_b)))

执行结果:

[518, 962, 23, 492, 848, 288]

第一个list:

[492, 848, 288]

第一个list的和为:1628

第二个list:

[518, 962, 23]

第二个list的和为:1503

题目二:

题目2:

有10个人要互赠礼物,要求:

1.每个人都要收到一份礼物

2.每个人都要送出一份礼物

3.不能送给自己

请写出一个程序,随机输出可以符合要求的送礼方案:

输出如下:

1 => 4

2 => 5

3 => 8

......

# -*- coding:utf-8 -*-

import random

import itertools

g_list=[]

for i in range(1,11,1):

g_list.append(i)

print(g_list)

'''for p in itertools.combinations(g_list,2):

print(p)'''

map_people = []

#生成二维数组,每一行代表一个学生,第一个数据为学生编码,第二个为拥有的礼物,第三个为收到的礼物

for i in range(0, 10):

map_people += [[]]

map_people[i] += [i+1]

map_people[i] += [1]

map_people[i] += [0]

print("原始数据")

print(map_people)

for i in range(10):

j = random.randint(0, 9)

while(i == j):

j = random.randint(0, 9)

map_people[i][1] = map_people[i][1] - 1

map_people[j][2] = map_people[j][2] + 1

print("%d => %d" % (i,j))

print("第一轮:随机赠送,每人都要赠出礼物,得到的列表")

print(map_people)

for k in range(10):

if map_people[k][2] > 1:

for m in range(10):

if map_people[m][2] == 0:

if map_people[k][2] > 1 :

map_people[k][2] = map_people[k][2] - 1

map_people[m][2] = map_people[m][2] + 1

print("%d => %d" % (k,m))

print("第二轮:得到礼物大于1的,把多的礼物赠与无礼物的人,得到的列表")

print(map_people)

原始数据

[[1, 1, 0], [2, 1, 0], [3, 1, 0], [4, 1, 0], [5, 1, 0], [6, 1, 0], [7, 1, 0], [8, 1, 0], [9, 1, 0], [10, 1, 0]]

0 => 7

1 => 2

2 => 4

3 => 0

4 => 6

5 => 8

6 => 3

7 => 4

8 => 5

9 => 2

第一轮:随机赠送,每人都要赠出礼物,得到的列表

[[1, 0, 1], [2, 0, 0], [3, 0, 2], [4, 0, 1], [5, 0, 2], [6, 0, 1], [7, 0, 1], [8, 0, 1], [9, 0, 1], [10, 0, 0]]

2 => 1

4 => 9

第二轮:得到礼物大于1的,把多的礼物赠与无礼物的人,得到的列表

[[1, 0, 1], [2, 0, 1], [3, 0, 1], [4, 0, 1], [5, 0, 1], [6, 0, 1], [7, 0, 1], [8, 0, 1], [9, 0, 1], [10, 0, 1]]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值