이 글은 주로 추측 게임 크래킹 알고리즘을 구현하기 위한 Python을 소개하고, 추측 게임의 원리를 간략하게 설명하며, 추측 게임 크래킹을 위한 Python의 관련 구현 기술을 구체적인 예의 형태로 분석합니다. 도움이 필요한 친구들은 참고할 수 있습니다. 이 기사에
이 예는 추측 게임 알고리즘을 해독하기 위한 Python 구현을 알려줍니다. 참고용으로 모든 사람과 공유하세요. 세부 사항은 다음과 같습니다.
QQ 그룹의 채팅 로봇이 추측 게임을 시작합니다. 게임 플레이는 다음과 같습니다.
1. 사용자가 그룹에 #guessing을 보냅니다.
2. 로봇이 응답합니다: 추측이 시작되었습니다. 범위는 1-10000입니다.
3. 그룹에 #guess[123]를 보냅니다.
4. 로봇이 응답합니다: 크거나 작거나 추측한 것을 축하합니다
5. 방금 추측한 내용을 바탕으로 123을 추측하고 반환하여 더 작거나 큰 숫자를 추측하고 #guess[111]를 보냅니다. 즉, 2단계로 돌아갑니다
그러면 가장 좋은 추측 방법은 확실히 중간 숫자를 찾는 것입니다. 왜냐하면 암산 계산은 시간이 많이 걸리므로 Python 스크립트를 직접 사용하여 이를 해독하세요.
#!/usr/bin/env python # -*- coding: utf-8 -*- __author__ = 'huhu, <huyoo353@126.com>' def find_middle(start, end): #print start, end return round((start+end)/2.0) if __name__ == '__main__': start, end = '','' text = raw_input(u"> 输入猜数的范围(如:421-499 或者421 499 或者421,499):").decode('gb18030') spliters = '-, ' for c in spliters: if text.find(c) != -1: num_list = text.split(c) if ''.join(num_list).isdigit(): start, end = num_list[0],num_list[1] break if start == '' or end == '': print u'范围不正确' else: start = int(start) end = int(end) count = 1 last_guess = find_middle(start,end) while 1: result = raw_input(u"放弃猜测直接回车, 等于输入=, 小了输入1, 大了请输入2\n>>> #猜数[%d] ,对吗?> " % last_guess ).decode('gb18030') #print type(text) if result in ['q','e','exit','quit','bye',u'退出']: print 'Bye!' break else: result=result.strip() if result == '1': start = last_guess last_guess = find_middle(last_guess,end) elif result == '2': end = last_guess last_guess = find_middle(start,last_guess) elif result == '=': print u'恭喜猜中, 共猜了%d次' % count print u'#猜数[%d]' % last_guess break else: # continue count += 1
위 내용은 Python을 사용한 추측 게임 크래킹의 예에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!