Python implements the guessing number game of of without repeating number examples to share
- 2020-04-02 13:29:45
- OfStack
import time, random
class GuessNum:
def __init__(self):
self._num = ''
self.input_num = []
self.count = 1 # Number of correct guesses
self.sec = 0 # Time to guess right
self._generate_num()
def _generate_num(self): # Generate four Numbers that do not repeat
seq_zton = list(range(10))
for i in range(0, 4):
a = str(random.choice(seq_zton)) # Pick a number
self._num += a
seq_zton.remove(int(a)) # Pay attention to a The type of
self.sec = time.clock() # Start the time
def check_answer(self):
return self._num
def check_input(self):
num_pos, num_value = 0, 0 # The number of positional pairs and numerical pairs
tmp = input("Please input the number you guess(No repetition),or 'c' to check the answer:")
if tmp == 'c':
print(self.check_answer())
tof = self.check_input()
return tof
elif not tmp.isalnum or not len(tmp) == 4:
print("Wrong format!")
tof = self.check_input() # Need to optimize
return tof
self.input_num = list(tmp)
lst_temp = list(self._num)
if self.input_num == lst_temp: # Guess the
self.prt_vic()
return True
for i in lst_temp:
if i in self.input_num:
if lst_temp.index(i) == self.input_num.index(i): # Same position
num_pos += 1
num_value += 1
else:
num_value += 1
self.prt_state(num_pos, num_value)
self.count += 1
return False
def prt_state(self, num_pos, num_value):
print("You've got %d numbers with the right position and %d numbers with the right value only" % (num_pos, num_value))
def prt_vic(self):
t = time.clock()
self.sec = t - self.sec
print("Congratulations!You have successfully got the right number!")
print("%d times and %.2f sec in total to get the right answer" % (self.count, self.sec))
gn = GuessNum()
while True:
ss = gn.check_input()
if ss:
b = input("Continue? y/n:")
if b == 'n':
break
else:
gn = GuessNum()
continue