-
Notifications
You must be signed in to change notification settings - Fork 422
/
PickCards.py
113 lines (78 loc) · 2.64 KB
/
PickCards.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
"""
貌似今日头条笔试?第三题。
两个人选卡牌,每张卡牌都有两个分值 x, y。选到卡牌时x加给自己,y加给团队。
给一组卡牌,求两个人选的卡牌 x 相等且y最大的情况。
思路:
根据 y 的分值先排序。
之后进行判断:
若里面的x相加是奇数直接跳过,在进行一次将此时下标排除的判断,最后都不通过将最小的一个y值的卡牌放入废弃池。
若里面的x相加是偶数:
排序:
1. 取末尾一个数,若大于目标(x相加/2)则返回 False。将最小的一个y值的卡牌放入废弃池。
2. 等于直接返回True.
3. 小于的情况减去。
对剩余的进行Dp:
每一个都有两种操作:
1. 减去或不减。
2. 大于的不减,小于的也可以不减。
3. 直到有一个是0或都不是,返回 False。
---
判断还是这么判断,只不过不废弃了,直接用itertools生成从大到小生成数据,先倒序,然后len(x) - 2
这样直接返回只适用于没有负数的情况,若有负数需要全部计算后在进行判断。
此种方法属于暴力法...效率不高.
最差会有
n * (n-1) / (n - 1) + n * (n-1) / (n-2) ....次。
做完3道已经用了接近两个小时。。
"""
test = [
[3, 1],
[2, 2],
[1, 4],
[1, 4]
]
test2 = [
[7, 1],
[6, 2],
[5, 3],
[4, 4],
[3, 5],
[2, 6],
[1, 7],
[1, 7]
]
import itertools
def maxCardsScope(cards):
cards = sorted(cards, key=lambda x: x[1], reverse=True)
result_cards = {}
currentCards = cards
allCardsScopes = sum([x[0] for x in cards])
if allCardsScopes % 2 == 0:
if judgeEqual(cards, allCardsScopes / 2):
return sum([x[1] for x in cards])
# result_cards[sum([x[1] for x in cards])] = [cards]
for x in range(len(cards)-1, 1, -1):
for i in itertools.combinations(cards, x):
temp = sum([t[0] for t in i])
if temp % 2 != 0:
continue
if judgeEqual(i, temp / 2):
return sum([t[1] for t in i])
def judgeEqual(cards, target):
cards = sorted(cards, key=lambda x: x[0], reverse=True)
if cards[0][0] == target:
return True
if cards[0][0] > target:
return False
if cards[0][0] < target:
# init = target - cards[0][0]
dp = {-1: [target]}
for i, d in enumerate(cards):
temp = dp[i-1].copy()
for x in dp[i-1]:
if x - d[0] == 0:
return True
if x - d[0] > 0:
temp.append(x - d[0])
dp[i] = temp
return False
print(maxCardsScope(test2))