Initial import

git-svn-id: file:///srv/svn/euler@1 e5f4c3ec-3c0c-11df-b522-21efaa4426b5
This commit is contained in:
Correl Roush 2010-03-30 15:01:13 +00:00
commit 27734df4c4
6 changed files with 4174 additions and 0 deletions

6
001/001.py Normal file
View file

@ -0,0 +1,6 @@
total = 0
for x in range(1000):
if (0 == x % 3) or (0 == x % 5):
total = total + x
print 'Answer', total

17
002/002.py Normal file
View file

@ -0,0 +1,17 @@
# -*- coding: utf-8 -*-
# Each new term in the Fibonacci sequence is generated by adding the previous two terms. By starting with 1 and 2, the first 10 terms will be:
# 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, ...
# Find the sum of all the even-valued terms in the sequence which do not exceed four million.
limit = 4000000
#limit = 90
last = [0, 1]
x = 1
total = 0
while (x < limit):
if (0 == x % 2):
total += x
last.append(x)
last = last[-2:]
x = sum(last)
print 'Answer', total

145
054/054.py Normal file
View file

@ -0,0 +1,145 @@
import operator
class PokerCard:
values = {'T': 10, 'J': 11, 'Q': 12, 'K': 13, 'A': 14}
def __init__(self, string):
self.value = string[0]
if self.value in '23456789':
self.value = int(self.value)
else:
self.value = PokerCard.values[self.value]
self.suit = string[1]
@staticmethod
def compare(a, b):
if a.value > b.value:
return 1
elif a.value == b.value:
return 0
else:
return -1
class PokerHand:
HIGH_CARD = 0
ONE_PAIR = 1
TWO_PAIRS = 2
THREE_OF_A_KIND = 3
STRAIGHT = 4
FLUSH = 5
FULL_HOUSE = 6
FOUR_OF_A_KIND = 7
STRAIGHT_FLUSH = 8
ROYAL_FLUSH = 9
RANKS = [
'High Card',
'One Pair',
'Two Pairs',
'Three of a Kind',
'Straight',
'Flush',
'Full House',
'Four of a Kind',
'Straight Flush',
'Royal Flush'
]
def __init__(self, cards):
self._rank = None
self._cards = sorted([PokerCard(c) for c in cards], cmp=PokerCard.compare, reverse=True)
self._values = []
self.rank()
def __str__(self):
return str.format("Cards: {0} Rank: '{1}' Values: {2}",
[str(c.value) + c.suit for c in self._cards],
PokerHand.RANKS[self.rank()],
self.values())
def rank(self):
if self._rank:
return self._rank
flush = True
straight = False
last = None
merged = {}
for c in self._cards:
if last:
if flush and c.suit != last.suit:
flush = False
last = c
if c.value in merged:
merged[c.value] = merged[c.value] + 1
else:
merged[c.value] = 1
if (len(merged)) == 5:
# All unique cards, check for a straight
if self._cards[0].value - self._cards[4].value == 4 or \
(self._cards[4].value == 2 and self._cards[1].value == 5 and self._cards[0].value == 14):
straight = True
if straight and flush:
if self._cards[4] == 14:
self._rank = PokerHand.ROYAL_FLUSH
else:
self._rank = PokerHand.STRAIGHT_FLUSH
elif flush:
self._rank = PokerHand.FLUSH
elif straight:
self._rank = PokerHand.STRAIGHT
else:
self._rank = PokerHand.HIGH_CARD
self._values = [c.value for c in self._cards]
else:
multiples = [m for m in sorted(merged.items(), key = operator.itemgetter(1), reverse = True) if m[1] > 1]
if len(multiples) > 1:
if multiples[0][1] == multiples[1][1]:
self._rank = PokerHand.TWO_PAIRS
else:
self._rank = PokerHand.FULL_HOUSE
else:
if multiples[0][1] > 3:
self._rank = PokerHand.FOUR_OF_A_KIND
elif multiples[0][1] == 3:
self._rank = PokerHand.THREE_OF_A_KIND
else:
self._rank = PokerHand.ONE_PAIR
mvalues = [m[0] for m in multiples]
self._values = mvalues + [c.value for c in self._cards if c.value not in mvalues]
return self._rank
def values(self):
if not self._values:
self.rank()
return self._values
@staticmethod
def compare(a, b):
# Compare hand rankings
result = cmp(a.rank(), b.rank())
if (result == 0):
# Compare hand values
for i in range(len(a.values())):
result = cmp(a.values()[i], b.values()[i])
if (result != 0):
return result
return result
wins = 0
counter = 0
with open('poker.txt', 'r') as f:
while True:
line = f.readline()
if not line:
break
counter = counter + 1
cards = line.strip().split()
one = PokerHand(cards[:5])
two = PokerHand(cards[-5:])
result = PokerHand.compare(one, two)
if result > 0:
wins = wins + 1
outcome = 'Player One wins'
elif result == 0:
outcome = 'Tie'
else:
outcome = 'Player Two wins'
print "Hand #{0}: {1}\n {2}\n {3}".format(
counter,
outcome,
one,
two)
print "Player one won {0} hands".format(wins)

3001
054/output.txt Normal file

File diff suppressed because it is too large Load diff

1000
054/poker.txt Normal file

File diff suppressed because it is too large Load diff

5
054/pokertest.txt Normal file
View file

@ -0,0 +1,5 @@
5H 5C 6S 7S KD 2C 3S 8S 8D TD
5D 8C 9S JS AC 2C 5C 7D 8S QH
2D 9C AS AH AC 3D 6D 7D TD QD
4D 6S 9H QH QC 3D 6D 7H QD QS
2H 2D 4C 4D 4S 3C 3D 3S 9S 9D