猜数字(Bulls and Cows)如何用python实现?

猜数字具体规则见:http://baike.baidu.com/subview/358630/11117097.htm

玩家和电脑对抗的模式,玩法为猜数字游戏标准玩法。

游戏流程:

执行guess.py文件开始游戏。

脚本随机生成一个没有重复的4位数字作为被猜数字。

玩家和电脑轮流猜数字。

玩家通过命令行输入数字,脚本打印出1A1B样式的测试结果。

脚本打印出电脑的猜测数字和结果。电脑不能使用玩家的猜测结果。

重复此过程直至一方猜中。

打印出胜利者的信息,脚本结束执行。

要求:

使用python2.7版本

使用一个py文件来实现,命名为guess.py,完成上述玩法需求。

guess.py文件可以作为模块被其他脚本调用,提供如下接口:

check:根据猜测数和预期数2个参数返回1A1B格式结果。

calculate:根据猜测数、该猜测数的1A1B格式结果,返回所有可能是正确答案的数据集。

在github上有一个比较完善的程序(python3.0)https://github.com/vpavlenko/bulls-and-cows/blob/master/solver.py

这两天我自己写好的python2.7代码:

#!/usr/bin/python
# -*- coding:utf-8 -*-


import random


def random_num():
#生成4位无重复数字的随机数(首位不可为0)
    com_num = random.sample('123456789', 4)
    com_num = ''.join(com_num)
    return com_num

def player_input():
#判断玩家输入合法性
    while(True):
        try:
            global player_num
            player_num = str(raw_input('\nYour turn! Enter Your Guess Number:'))
            z = int(player_num)
            if(len(player_num) != 4):
                print('Please enter a 4 DIGIT number.')
                continue

        except ValueError:
            if player_num == 'quit':
                exit()
            print('Your input is not a number.')

        else:
            if(len(set(player_num)) != 4):
                print('Please enter a number with different digits.')
                continue
            elif player_num[0] == 0:
                print('Please enter a number that first number is not 0.')
                continue
            else:
                return

def check(number, question):
#根据猜测数和被猜数计算返回1A1B样式的结果"(1, 1)"
    number = str(number)
    question = str(question)
    global a_count
    global b_count
    a_count = 0
    b_count = 0

    for i in range(4):
        for j in range(4):
            if(number[i] == question[j]):
                if(i == j):
                    a_count += 1
                else:
                    b_count += 1

    return (a_count, b_count)   

def allowed_number(number):
#判断数字合法性
    return len(str(number)) == 4 and len(set(str(number))) == 4

all_numbers = [number for number in range(1234, 9877) if allowed_number(number)]
#所有可能结果

def calculate(number, answer):
#根据猜测数和1A1B结果计算返回所有可能结果
    number = str(number)
    global num_series
    num_series = []

    for possible_num in all_numbers:
        if not abs(cmp(check(possible_num, number), answer)):
            num_series.append(possible_num)

    return num_series

def history_rec(number):
#记录本轮游戏出现过的数字
    global history
    return history.append(int(number))

def del_history(num_series, history):
#删除本轮游戏中出现过的数字
    for number in history:
        if number in num_series:
            num_series.remove(number)  

    return num_series  

def ai_best():
#反馈个数指标评判答案最优解
    global best
    if not (best[0]+best[1] > answer[0]+answer[1]):
        if not (best[0] > answer[0]):
            best = answer

def history_area(num_series):
#计算保存最可能的值域,取历史值域及新值域的交集
    global area
    intersection = [i for i in area if i in num_series]
    intersection = list(set(area).intersection(set(num_series)))
    return intersection


print'''
----------Guess The Number Game: Player VS AI----------

You can input"quit"to exit

Rules:
1.Question number is a random 4 digit number without same digits (first digit can't be 0).

2.Player and AI guess the number one by one until Player Win or AI Win.

3.After every guess, program will return an answer of 1A1B like:"(1, 1)".
A value is the number of digit and position are all correct.
B value is just the number of digit is correct (position is wrong).'''

player_num = 0
ai_num = 0
random_number = random_num()
player_turn = 1
answer = (0, 0)
a_count = 0
best = (0, 0)
history = []
area = all_numbers

while(a_count != 4):
    question = random_number
    num_series = []
#玩家的回合
    if player_turn:
        player_input()
        history_rec(player_num)
        answer = check(player_num, question)
        a_count = answer[0]
        print "\nYour choice is", player_num
        print "Your answer is", answer
        ai_best()
#电脑的回合
    else:
        ai_num = random.choice(area)
        history_rec(ai_num)
        answer = check(ai_num, question)
        a_count = answer[0]
        print "\nAI's choice is", ai_num
        print "AI's answer is", answer
        ai_best()

    num_series = del_history(calculate(player_num, best), history)
    area = history_area(num_series)
    print num_series
    print area
    player_turn = not player_turn
#输出胜负结果    
if player_turn:
    print("\nYou Win!")      
else:
    print("\nAI Win!")

但是运行几次老是报错

Traceback (most recent call last):
  File "C:\Python27\guess.py", line 144, in <module>
    ai_num = random.choice(area)
  File "C:\Python27\lib\random.py", line 275, in choice
    return seq[int(self.random() * len(seq))]  # raises IndexError if seq is empty
IndexError: list index out of range

2个回答

nonlocal不支持python 2.x
https://cndenis.iteye.com/blog/1754743

python 2.x 官方马上就不维护了 最好用3.x 版本

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
Arrange the Bulls
问题描述 : Farmer Johnson’s Bulls love playing basketball very much. But none of them would like to play basketball with the other bulls because they believe that the others are all very weak. Farmer Johnson has N cows (we number the cows from 1 to N) and M barns (we number the barns from 1 to M), which is his bulls’ basketball fields. However, his bulls are all very captious, they only like to play in some specific barns, and don’t want to share a barn with the others. So it is difficult for Farmer Johnson to arrange his bulls, he wants you to help him. Of course, find one solution is easy, but your task is to find how many solutions there are. You should know that a solution is a situation that every bull can play basketball in a barn he likes and no two bulls share a barn. To make the problem a little easy, it is assumed that the number of solutions will not exceed 10000000. 输入: In the first line of input contains two integers N and M (1 <= N <= 20, 1 <= M <= 20). Then come N lines. The i-th line first contains an integer P (1 <= P <= M) referring to the number of barns cow i likes to play in. Then follow P integers, which give the number of there P barns. 输出: Print a single integer in a line, which is the number of solutions. 样例输入: 3 4 2 1 4 2 1 3 2 2 4 样例输出: 4
关于java越界的问题。。。。请大神解答
public class Solution { public String getHint(String secret, String guess) { int bulls=0; int cows=0; char[] sec = secret.toCharArray(); char[] gue = guess.toCharArray(); int[] s=new int[10]; int[] g=new int[10]; for(int i=0;i<sec.length;i++){ if(sec[i]==gue[i]){ bulls++; }else{ s[sec[i]-'0']++; g[gue[i]-'0']++; } } for(int j=0;j<g.length;j++){ cows+=Math.min(s[j],g[j]); } return bulls+"A"+cows+"B"; } } 我不明白为什么要在s[sec[i]-'0']++;g[gue[i]-'0']++处-‘0’;而如果改为+‘0’,就会报越界错误Line 13: java.lang.ArrayIndexOutOfBoundsException: 97。请大神解答
Romeo Meets Juliet
Description Farmer John has two feuding herds of cattle, the Moontagues and the Cowpulets. One of the bulls in the Moontague herd, Romeo, has fallen in love with Juliet, a Cowpulet. Romeo would like to meet with Juliet, but he doesn't want the other members of the Cowpulet herd to find out. Romeo and Juliet want to meet and graze in as large a region as possible along the pasture fence. However, this region should not contain too many Cowpulets, otherwise the chance of the two being caught is too great. Romeo has determined where along the fence each of the N (1 <= N <= 1000) members of the Cowpulet herd grazes. The long straight fence contains P (1 <= P <= 1000) equally-spaced posts numbered 1..P. Each Cowpulet grazes between some pair of adjacent posts. Help Romeo determine the length of the largest contiguous region along the fence containing no more than C (0 <= C <= 1000) members of the Cowpulet herd. Input * Line 1: Three separated integers: N, P, and C * Lines 2..N+1: Each line contains an integer X, in the range 1..P-1, specifying that a member of the Cowpulet herd grazes between fence posts X and X+1. Multiple Cowpulets can graze between any given pair of fence posts. Output * Line 1: A single integer specifying the size (the number of gaps between fence posts) of the largest contiguous region containing at most C Cowpulets. Sample Input 2 6 1 2 3 Sample Output 3
Dart-a-Mania
Description The game of darts has many variations. One such variation is the game of 301. In the game of 301 each player starts with a score of 301 (hence the name). Each player, in turn, throws three darts to score points which are subtracted from the player's current score. For instance, if a player has a current score of 272 and scores 55 points with the three darts, the new score would be 217. Each dart that is tossed may strike regions on the dartboard that are numbered between 1 and 20. (A value of zero indicates that the player either missed the dartboard altogether or elected to not throw the dart.) A dart that strikes one of these regions will either score the number printed on the dartboard, double the number printed, or triple the number printed. For example, a player may score 17, 34, or 51 points with a toss of one dart that hits one of the regions marked with a 17. A third way to score points with one dart is to hit the BULLS EYE which is worth 50 points. (There is no provision for doubling or tripling the bull's eye score.) The first player to reduce his score to exactly zero wins the game. If a player scores more points than his/her current score, the player is said to have "busted" and the new score is returned to the last current score. Problem Statement Given a player's current dart score, write a program to calculate all the possible combinations and permutations of scores on throwing three darts that would reduce the player's score to exactly zero (meaning the player won the game). The output of the program should contain the number of combinatons and permutations found. For example, if the player's current score is 2, then there would be two combinations and six permutations. The combinations would be: 1) obtain a score of 2 on any one dart and zero on the other two, and 2) obtain a score of one on two different darts and zero on the third dart. The order in which this is accomplished is not important. With permutations the order is significant; therefore the six permutations would be as follows: Dart 1: 2 0 0 1 1 0 Dart 2: 0 2 0 1 0 1 Dart 3: 0 0 2 0 1 1 (Note: The program doesn't print out the actual permutations & combinations, just the total number of each.) Input The input contains a list of integers (each <= 999), one per line, that represent several players' current scores. A value of zero or less will signify the end of the input file. Output For each positive integer in the input file, 2 or 3 line(s) will be written to the std output. If the score can be reduced to zero, your program should write the lines: NUMBER OF COMBINATIONS THAT SCORES x IS c. NUMBER OF PERMUTATIONS THAT SCORES x IS p. where x is the value of the player's score while c and p are the total number of combinations and permutations possible, respectively. If it is impossible to reduce the player's score to zero, write the line: THE SCORE OF x CANNOT BE MADE WITH THREE DARTS. After the line(s) above are printed, your program should write a line of 70 asterisks to separate output for different scores. The message "END OF OUTPUT" should appear at the end of the output file. Sample Input 162 175 2 68 211 114 -100 Sample Output NUMBER OF COMBINATIONS THAT SCORES 162 IS 7. NUMBER OF PERMUTATIONS THAT SCORES 162 IS 28. ********************************************************************** THE SCORE OF 175 CANNOT BE MADE WITH THREE DARTS. ********************************************************************** NUMBER OF COMBINATIONS THAT SCORES 2 IS 2. NUMBER OF PERMUTATIONS THAT SCORES 2 IS 6. ********************************************************************** NUMBER OF COMBINATIONS THAT SCORES 68 IS 187. NUMBER OF PERMUTATIONS THAT SCORES 68 IS 1056. ********************************************************************** THE SCORE OF 211 CANNOT BE MADE WITH THREE DARTS. ********************************************************************** NUMBER OF COMBINATIONS THAT SCORES 114 IS 82. NUMBER OF PERMUTATIONS THAT SCORES 114 IS 445. ********************************************************************** END OF OUTPUT
android,JSON数据解析,解析集合里的数据,求代码
{"reason"=>"查询成功", "result"=>{"title"=>"NBA2015-2016赛季_季后赛视频直播_腾讯体育", "statuslist"=>{"st0"=>"未开赛", "st1"=>"直播中", "st2"=>"已结束"}, "list"=>[{"title"=>"06-17 周五", "tr"=>[{"time"=>"06/17 09:00", "player1"=>"勇士", "player2"=>"骑士", "player1logo"=>"http://p8.qhimg.com/t01dae3099bd6904c43.png?size=78x78", "player2logo"=>"http://p8.qhimg.com/t0162a1fa2ce42538d1.png?size=78x78", "player1logobig"=>"http://p4.qhimg.com/t01dae3099bd6904c43.png?size=78x78", "player2logobig"=>"http://p7.qhimg.com/t0162a1fa2ce42538d1.png?size=78x78", "player1url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=9", "player2url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=5", "link1url"=>"http://sports.qq.com/kbsweb/game.htm?mid=100000:1468534", "m_link1url"=>"http://j.www.haosou.com/?u=http%3A%2F%2Fsports.qq.com%2Fkbsweb%2Fkbsshare%2Fgame.htm%3Fmid%3D100000%3A1468534%26title%3D%25E5%258B%2587%25E5%25A3%25ABVS%25E9%25AA%2591%25E5%25A3%25AB%26ptag%3D360.onebox.schedule.nba&m=a3b604&from=juhe&type=nba_new&juid=JH2ec2faa49e90cd3822831cf3d019cbdb", "link2text"=>"技术统计", "link2url"=>"http://sports.qq.com/nbascore/?mid=1468534", "m_link2url"=>"http://j.www.haosou.com/?u=http%3A%2F%2Fsports.qq.com%2Fkbsweb%2Fkbsshare%2Fgame.htm%3Fmid%3D100000%3A1468534%26title%3D%25E5%258B%2587%25E5%25A3%25ABVS%25E9%25AA%2591%25E5%25A3%25AB%26ptag%3D360.onebox.schedule.nba&m=a3b604&from=juhe&type=nba_new&juid=JH2ec2faa49e90cd3822831cf3d019cbdb", "status"=>2, "score"=>"101-115", "link1text"=>"视频集锦"}], "bottomlink"=>[{"text"=>"季后赛赛程", "url"=>"http://sports.qq.com/nba/schedule/?ptag=360.onebox.schedule.nba"}, {"text"=>"球队排名", "url"=>"http://sports.qq.com/nba/standings/?ptag=360.onebox.schedule.nba"}, {"text"=>"球员排名", "url"=>"http://nbadata.sports.qq.com/stats/player/2015playerstatsindex.html?ptag=360.onebox.schedule.nba"}, {"text"=>"社区讨论", "url"=>"http://sports.qq.com/fans/group.htm?mid=69"}]}, {"title"=>"06-20 周一", "live"=>[{"title"=>"08:00开赛 比赛结束", "player1"=>"骑士", "player2"=>"勇士", "player1info"=>"胜57负25东部1名", "player2info"=>"胜73负9西部1名", "player1logobig"=>"http://p2.qhimg.com/t0162a1fa2ce42538d1.png?size=78x78", "player2logobig"=>"http://p8.qhimg.com/t01dae3099bd6904c43.png?size=78x78", "player1url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=5", "player2url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=9", "player1location"=>"(客)", "player2location"=>"(主)", "status"=>2, "score"=>"93-89", "liveurl"=>""}], "livelink"=>[{"text"=>"视频集锦", "url"=>"http://sports.qq.com/kbsweb/game.htm?mid=100000:1468535"}, {"text"=>"技术统计", "url"=>"http://sports.qq.com/nbascore/?mid=1468535"}], "tr"=>[{"time"=>"06/20 08:00", "player1"=>"骑士", "player2"=>"勇士", "player1logo"=>"http://p3.qhimg.com/t0162a1fa2ce42538d1.png?size=78x78", "player2logo"=>"http://p3.qhimg.com/t01dae3099bd6904c43.png?size=78x78", "player1logobig"=>"http://p2.qhimg.com/t0162a1fa2ce42538d1.png?size=78x78", "player2logobig"=>"http://p7.qhimg.com/t01dae3099bd6904c43.png?size=78x78", "player1url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=5", "player2url"=>"http://kbs.sports.qq.com/kbsweb/teams.htm?tid=9", "link1url"=>"http://sports.qq.com/kbsweb/game.htm?mid=100000:1468535", "m_link1url"=>"http://j.www.haosou.com/?u=http%3A%2F%2Fsports.qq.com%2Fkbsweb%2Fkbsshare%2Fgame.htm%3Fmid%3D100000%3A1468535%26title%3D%25E9%25AA%2591%25E5%25A3%25ABVS%25E5%258B%2587%25E5%25A3%25AB%26ptag%3D360.onebox.schedule.nba&m=dd3de8&from=juhe&type=nba_new&juid=JH2ec2faa49e90cd3822831cf3d019cbdb", "link2text"=>"技术统计", "link2url"=>"http://sports.qq.com/nbascore/?mid=1468535", "m_link2url"=>"http://j.www.haosou.com/?u=http%3A%2F%2Fsports.qq.com%2Fkbsweb%2Fkbsshare%2Fgame.htm%3Fmid%3D100000%3A1468535%26title%3D%25E9%25AA%2591%25E5%25A3%25ABVS%25E5%258B%2587%25E5%25A3%25AB%26ptag%3D360.onebox.schedule.nba&m=dd3de8&from=juhe&type=nba_new&juid=JH2ec2faa49e90cd3822831cf3d019cbdb", "status"=>2, "score"=>"93-89", "link1text"=>"视频集锦"}], "bottomlink"=>[{"text"=>"季后赛赛程", "url"=>"http://sports.qq.com/nba/schedule/?ptag=360.onebox.schedule.nba"}, {"text"=>"球队排名", "url"=>"http://sports.qq.com/nba/standings/?ptag=360.onebox.schedule.nba"}, {"text"=>"球员排名", "url"=>"http://nbadata.sports.qq.com/stats/player/2015playerstatsindex.html?ptag=360.onebox.schedule.nba"}, {"text"=>"社区讨论", "url"=>"http://sports.qq.com/fans/group.htm?mid=69"}]}], "teammatch"=>[{"name"=>"老鹰", "url"=>"http://sports.qq.com/nba/schedule/?team=hawks"}, {"name"=>"凯尔特人", "url"=>"http://sports.qq.com/nba/schedule/?team=celtics"}, {"name"=>"鹈鹕", "url"=>"http://sports.qq.com/nba/schedule/?team=pelicans"}, {"name"=>"公牛", "url"=>"http://sports.qq.com/nba/schedule/?team=bulls"}, {"name"=>"骑士", "url"=>"http://sports.qq.com/nba/schedule/?team=cavaliers"}, {"name"=>"小牛", "url"=>"http://sports.qq.com/nba/schedule/?team=mavericks"}, {"name"=>"掘金", "url"=>"http://sports.qq.com/nba/schedule/?team=nuggets"}, {"name"=>"活塞", "url"=>"http://sports.qq.com/nba/schedule/?team=pistons"}, {"name"=>"勇士", "url"=>"http://sports.qq.com/nba/schedule/?team=warriors"}, {"name"=>"火箭", "url"=>"http://sports.qq.com/nba/schedule/?team=rockets"}, {"name"=>"步行者", "url"=>"http://sports.qq.com/nba/schedule/?team=pacers"}, {"name"=>"快船", "url"=>"http://sports.qq.com/nba/schedule/?team=clippers"}, {"name"=>"湖人", "url"=>"http://sports.qq.com/nba/schedule/?team=lakers"}, {"name"=>"热火", "url"=>"http://sports.qq.com/nba/schedule/?team=heat"}, {"name"=>"雄鹿", "url"=>"http://sports.qq.com/nba/schedule/?team=bucks"}, {"name"=>"森林狼", "url"=>"http://sports.qq.com/nba/schedule/?team=timberwolves"}, {"name"=>"篮网", "url"=>"http://sports.qq.com/nba/schedule/?team=nets"}, {"name"=>"尼克斯", "url"=>"http://sports.qq.com/nba/schedule/?team=knicks"}, {"name"=>"魔术", "url"=>"http://sports.qq.com/nba/schedule/?team=magic"}, {"name"=>"76人", "url"=>"http://sports.qq.com/nba/schedule/?team=sixers"}, {"name"=>"太阳", "url"=>"http://sports.qq.com/nba/schedule/?team=suns"}, {"name"=>"开拓者", "url"=>"http://sports.qq.com/nba/schedule/?team=blazers"}, {"name"=>"国王", "url"=>"http://sports.qq.com/nba/schedule/?team=kings"}, {"name"=>"马刺", "url"=>"http://sports.qq.com/nba/schedule/?team=spurs"}, {"name"=>"雷霆", "url"=>"http://sports.qq.com/nba/schedule/?team=thunder"}, {"name"=>"爵士", "url"=>"http://sports.qq.com/nba/schedule/?team=jazz"}, {"name"=>"奇才", "url"=>"http://sports.qq.com/nba/schedule/?team=wizards"}, {"name"=>"猛龙", "url"=>"http://sports.qq.com/nba/schedule/?team=raptors"}, {"name"=>"灰熊", "url"=>"http://sports.qq.com/nba/schedule/?team=grizzlies"}, {"name"=>"黄蜂", "url"=>"http://sports.qq.com/nba/schedule/?team=hornets"}]}, "error_code"=>0}
相见恨晚的超实用网站
相见恨晚的超实用网站 持续更新中。。。
字节跳动视频编解码面经
三四月份投了字节跳动的实习(图形图像岗位),然后hr打电话过来问了一下会不会opengl,c++,shador,当时只会一点c++,其他两个都不会,也就直接被拒了。 七月初内推了字节跳动的提前批,因为内推没有具体的岗位,hr又打电话问要不要考虑一下图形图像岗,我说实习投过这个岗位不合适,不会opengl和shador,然后hr就说秋招更看重基础。我当时想着能进去就不错了,管他哪个岗呢,就同意了面试...
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过...
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
linux系列之常用运维命令整理笔录
本博客记录工作中需要的linux运维命令,大学时候开始接触linux,会一些基本操作,可是都没有整理起来,加上是做开发,不做运维,有些命令忘记了,所以现在整理成博客,当然vi,文件操作等就不介绍了,慢慢积累一些其它拓展的命令,博客不定时更新 free -m 其中:m表示兆,也可以用g,注意都要小写 Men:表示物理内存统计 total:表示物理内存总数(total=used+free) use...
比特币原理详解
一、什么是比特币 比特币是一种电子货币,是一种基于密码学的货币,在2008年11月1日由中本聪发表比特币白皮书,文中提出了一种去中心化的电子记账系统,我们平时的电子现金是银行来记账,因为银行的背后是国家信用。去中心化电子记账系统是参与者共同记账。比特币可以防止主权危机、信用风险。其好处不多做赘述,这一层面介绍的文章很多,本文主要从更深层的技术原理角度进行介绍。 二、问题引入 假设现有4个人...
python学习方法总结(内附python全套学习资料)
不要再问我python好不好学了 我之前做过半年少儿编程老师,一个小学四年级的小孩子都能在我的教学下独立完成python游戏,植物大战僵尸简单版,如果要肯花时间,接下来的网络开发也不是问题,人工智能也可以学个调包也没啥问题。。。。。所以python真的是想学就一定能学会的!!!! --------------------华丽的分割线-------------------------------- ...
python 简易微信实现(注册登录+数据库存储+聊天+GUI+文件传输)
socket+tkinter详解+简易微信实现 历经多天的努力,查阅了许多大佬的博客后终于实现了一个简易的微信O(∩_∩)O~~ 简易数据库的实现 使用pands+CSV实现数据库框架搭建 import socket import threading from pandas import * import pymysql import csv # 创建DataFrame对象 # 存储用户数据的表(...
程序员接私活怎样防止做完了不给钱?
首先跟大家说明一点,我们做 IT 类的外包开发,是非标品开发,所以很有可能在开发过程中会有这样那样的需求修改,而这种需求修改很容易造成扯皮,进而影响到费用支付,甚至出现做完了项目收不到钱的情况。 那么,怎么保证自己的薪酬安全呢? 我们在开工前,一定要做好一些证据方面的准备(也就是“讨薪”的理论依据),这其中最重要的就是需求文档和验收标准。一定要让需求方提供这两个文档资料作为开发的基础。之后开发...
网页实现一个简单的音乐播放器(大佬别看。(⊙﹏⊙))
今天闲着无事,就想写点东西。然后听了下歌,就打算写个播放器。 于是乎用h5 audio的加上js简单的播放器完工了。 演示地点演示 html代码如下` music 这个年纪 七月的风 音乐 ` 然后就是css`*{ margin: 0; padding: 0; text-decoration: none; list-...
Python十大装B语法
Python 是一种代表简单思想的语言,其语法相对简单,很容易上手。不过,如果就此小视 Python 语法的精妙和深邃,那就大错特错了。本文精心筛选了最能展现 Python 语法之精妙的十个知识点,并附上详细的实例代码。如能在实战中融会贯通、灵活使用,必将使代码更为精炼、高效,同时也会极大提升代码B格,使之看上去更老练,读起来更优雅。
数据库优化 - SQL优化
以实际SQL入手,带你一步一步走上SQL优化之路!
2019年11月中国大陆编程语言排行榜
2019年11月2日,我统计了某招聘网站,获得有效程序员招聘数据9万条。针对招聘信息,提取编程语言关键字,并统计如下: 编程语言比例 rank pl_ percentage 1 java 33.62% 2 cpp 16.42% 3 c_sharp 12.82% 4 javascript 12.31% 5 python 7.93% 6 go 7.25% 7 p...
通俗易懂地给女朋友讲:线程池的内部原理
餐盘在灯光的照耀下格外晶莹洁白,女朋友拿起红酒杯轻轻地抿了一小口,对我说:“经常听你说线程池,到底线程池到底是个什么原理?”
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
将代码部署服务器,每日早上定时获取到天气数据,并发送到邮箱。 也可以说是一个小型人工智障。 知识可以运用在不同地方,不一定非是天气预报。
经典算法(5)杨辉三角
杨辉三角 是经典算法,这篇博客对它的算法思想进行了讲解,并有完整的代码实现。
Python实例大全(基于Python3.7.4)
博客说明: 这是自己写的有关python语言的一篇综合博客。 只作为知识广度和编程技巧学习,不过于追究学习深度,点到即止、会用即可。 主要是基础语句,如三大控制语句(顺序、分支、循环),随机数的生成,数据类型的区分和使用; 也会涉及常用的算法和数据结构,以及面试题相关经验; 主体部分是针对python的数据挖掘和数据分析,主要先攻爬虫方向:正则表达式匹配,常用数据清洗办法,scrapy及其他爬虫框架,数据存储方式及其实现; 最后还会粗略涉及人工智能领域,玩转大数据与云计算、进行相关的预测和分析。
腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹?
昨天,有网友私信我,说去阿里面试,彻底的被打击到了。问了为什么网上大量使用ThreadLocal的源码都会加上private static?他被难住了,因为他从来都没有考虑过这个问题。无独有偶,今天笔者又发现有网友吐槽了一道腾讯的面试题,我们一起来看看。 腾讯算法面试题:64匹马8个跑道需要多少轮才能选出最快的四匹? 在互联网职场论坛,一名程序员发帖求助到。二面腾讯,其中一个算法题:64匹...
面试官:你连RESTful都不知道我怎么敢要你?
干货,2019 RESTful最贱实践
刷了几千道算法题,这些我私藏的刷题网站都在这里了!
遥想当年,机缘巧合入了 ACM 的坑,周边巨擘林立,从此过上了"天天被虐似死狗"的生活… 然而我是谁,我可是死狗中的战斗鸡,智力不够那刷题来凑,开始了夜以继日哼哧哼哧刷题的日子,从此"读题与提交齐飞, AC 与 WA 一色 ",我惊喜的发现被题虐既刺激又有快感,那一刻我泪流满面。这么好的事儿作为一个正直的人绝不能自己独享,经过激烈的颅内斗争,我决定把我私藏的十几个 T 的,阿不,十几个刷题网...
为啥国人偏爱Mybatis,而老外喜欢Hibernate/JPA呢?
关于SQL和ORM的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行了一番讨论,感触还是有一些,于是就有了今天这篇文。 声明:本文不会下关于Mybatis和JPA两个持久层框架哪个更好这样的结论。只是摆事实,讲道理,所以,请各位看官勿喷。 一、事件起因 关于Mybatis和JPA孰优孰劣的问题,争论已经很多年了。一直也没有结论,毕竟每个人的喜好和习惯是大不相同的。我也看...
SQL-小白最佳入门sql查询一
不要偷偷的查询我的个人资料,即使你再喜欢我,也不要这样,真的不好;
JavaScript 为什么能活到现在?
作者 | 司徒正美 责编 |郭芮 出品 | CSDN(ID:CSDNnews) JavaScript能发展到现在的程度已经经历不少的坎坷,早产带来的某些缺陷是永久性的,因此浏览器才有禁用JavaScript的选项。甚至在jQuery时代有人问出这样的问题,jQuery与JavaScript哪个快?在Babel.js出来之前,发明一门全新的语言代码代替JavaScript...
项目中的if else太多了,该怎么重构?
介绍 最近跟着公司的大佬开发了一款IM系统,类似QQ和微信哈,就是聊天软件。我们有一部分业务逻辑是这样的 if (msgType = "文本") { // dosomething } else if(msgType = "图片") { // doshomething } else if(msgType = "视频") { // doshomething } else { // doshom...
Nginx 原理和架构
Nginx 是一个免费的,开源的,高性能的 HTTP 服务器和反向代理,以及 IMAP / POP3 代理服务器。Nginx 以其高性能,稳定性,丰富的功能,简单的配置和低资源消耗而闻名。 Nginx 的整体架构 Nginx 里有一个 master 进程和多个 worker 进程。master 进程并不处理网络请求,主要负责调度工作进程:加载配置、启动工作进程及非停升级。worker 进程负责处...
致 Python 初学者
欢迎来到“Python进阶”专栏!来到这里的每一位同学,应该大致上学习了很多 Python 的基础知识,正在努力成长的过程中。在此期间,一定遇到了很多的困惑,对未来的学习方向感到迷茫。我非常理解你们所面临的处境。我从2007年开始接触 python 这门编程语言,从2009年开始单一使用 python 应对所有的开发工作,直至今天。回顾自己的学习过程,也曾经遇到过无数的困难,也曾经迷茫过、困惑过。开办这个专栏,正是为了帮助像我当年一样困惑的 Python 初学者走出困境、快速成长。希望我的经验能真正帮到你
Python 编程开发 实用经验和技巧
Python是一门很灵活的语言,也有很多实用的方法,有时候实现一个功能可以用多种方法实现,我这里总结了一些常用的方法和技巧,包括小数保留指定位小数、判断变量的数据类型、类方法@classmethod、制表符中文对齐、遍历字典、datetime.timedelta的使用等,会持续更新......
吐血推荐珍藏的Visual Studio Code插件
作为一名Java工程师,由于工作需要,最近一个月一直在写NodeJS,这种经历可以说是一部辛酸史了。好在有神器Visual Studio Code陪伴,让我的这段经历没有更加困难。眼看这段经历要告一段落了,今天就来给大家分享一下我常用的一些VSC的插件。 VSC的插件安装方法很简单,只需要点击左侧最下方的插件栏选项,然后就可以搜索你想要的插件了。 下面我们进入正题 Material Theme ...
“狗屁不通文章生成器”登顶GitHub热榜,分分钟写出万字形式主义大作
一、垃圾文字生成器介绍 最近在浏览GitHub的时候,发现了这样一个骨骼清奇的雷人项目,而且热度还特别高。 项目中文名:狗屁不通文章生成器 项目英文名:BullshitGenerator 根据作者的介绍,他是偶尔需要一些中文文字用于GUI开发时测试文本渲染,因此开发了这个废话生成器。但由于生成的废话实在是太过富于哲理,所以最近已经被小伙伴们给玩坏了。 他的文风可能是这样的: 你发现,...
程序员:我终于知道post和get的区别
是一个老生常谈的话题,然而随着不断的学习,对于以前的认识有很多误区,所以还是需要不断地总结的,学而时习之,不亦说乎
《程序人生》系列-这个程序员只用了20行代码就拿了冠军
你知道的越多,你不知道的越多 点赞再看,养成习惯GitHub上已经开源https://github.com/JavaFamily,有一线大厂面试点脑图,欢迎Star和完善 前言 这一期不算《吊打面试官》系列的,所有没前言我直接开始。 絮叨 本来应该是没有这期的,看过我上期的小伙伴应该是知道的嘛,双十一比较忙嘛,要值班又要去帮忙拍摄年会的视频素材,还得搞个程序员一天的Vlog,还要写BU...
加快推动区块链技术和产业创新发展,2019可信区块链峰会在京召开
11月8日,由中国信息通信研究院、中国通信标准化协会、中国互联网协会、可信区块链推进计划联合主办,科技行者协办的2019可信区块链峰会将在北京悠唐皇冠假日酒店开幕。   区块链技术被认为是继蒸汽机、电力、互联网之后,下一代颠覆性的核心技术。如果说蒸汽机释放了人类的生产力,电力解决了人类基本的生活需求,互联网彻底改变了信息传递的方式,区块链作为构造信任的技术有重要的价值。   1...
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
Python3.7黑帽编程——病毒篇(基础篇)
引子 Hacker(黑客),往往被人们理解为只会用非法手段来破坏网络安全的计算机高手。但是,黑客其实不是这样的,真正的“网络破坏者”是和黑客名称和读音相似的骇客。 骇客,是用黑客手段进行非法操作并为己取得利益的人。黑客,是用黑客手段为国家或单位做事的人。 那么,既然黑客不是一个很坏的职业,我们就可以去试着学习。 黑客本身的初衷 ——黑客其实一直是善良的。 骇客其实他的前身就是黑客。 骇客与黑客分家...
程序员把地府后台管理系统做出来了,还有3.0版本!12月7号最新消息:已在开发中有github地址
第一幕:缘起 听说阎王爷要做个生死簿后台管理系统,我们派去了一个程序员…… 996程序员做的梦: 第一场:团队招募 为了应对地府管理危机,阎王打算找“人”开发一套地府后台管理系统,于是就在地府总经办群中发了项目需求。 话说还是中国电信的信号好,地府都是满格,哈哈!!! 经常会有外行朋友问:看某网站做的不错,功能也简单,你帮忙做一下? 而这次,面对这样的需求,这个程序员...
网易云6亿用户音乐推荐算法
网易云音乐是音乐爱好者的集聚地,云音乐推荐系统致力于通过 AI 算法的落地,实现用户千人千面的个性化推荐,为用户带来不一样的听歌体验。 本次分享重点介绍 AI 算法在音乐推荐中的应用实践,以及在算法落地过程中遇到的挑战和解决方案。 将从如下两个部分展开: AI算法在音乐推荐中的应用 音乐场景下的 AI 思考 从 2013 年 4 月正式上线至今,网易云音乐平台持续提供着:乐屏社区、UGC...
8年经验面试官详解 Java 面试秘诀
作者 |胡书敏 责编 | 刘静 出品 | CSDN(ID:CSDNnews) 本人目前在一家知名外企担任架构师,而且最近八年来,在多家外企和互联网公司担任Java技术面试官,前后累计面试了有两三百位候选人。在本文里,就将结合本人的面试经验,针对Java初学者、Java初级开发和Java开发,给出若干准备简历和准备面试的建议。 Java程序员准备和投递简历的实...
面试官如何考察你的思维方式?
1.两种思维方式在求职面试中,经常会考察这种问题:北京有多少量特斯拉汽车?某胡同口的煎饼摊一年能卖出多少个煎饼?深圳有多少个产品经理?一辆公交车里能装下多少个乒乓球?一个正常成年人有多少根头发?这类估算问题,被称为费米问题,是以科学家费米命名的。为什么面试会问这种问题呢?这类问题能把两类人清楚地区分出来。一类是具有文科思维的人,擅长赞叹和模糊想象,它主要依靠的是人的第一反应和直觉,比如小孩...
17张图带你解析红黑树的原理!保证你能看懂!
二叉查找树 由于红黑树本质上就是一棵二叉查找树,所以在了解红黑树之前,咱们先来看下二叉查找树。 二叉查找树(Binary Search Tree),也称有序二叉树(ordered binary tree),排序二叉树(sorted binary tree),是指一棵空树或者具有下列性质的二叉树: 若任意结点的左子树不空,则左子树上所有结点的值均小于它的根结点的值; 若任意结点的...
用Go重构C语言系统,这个抗住春晚红包的百度转发引擎承接了万亿流量
整理 | 夕颜出品 | AI科技大本营(ID:rgznai100)11 月 20 日,百度的万亿流量转发引擎 BFE 登上了 GitHub Trending Top 3,今日 Star 已突破 270。事实上,这个曾经抗住 2019 年春晚抢红包的转发引擎早已于 2019 年夏在 GitHub 上开源,今天突然再次引发关注,那我们不妨来回顾一下这个项目。 首先奉上 Gi...
so easy! 10行代码写个"狗屁不通"文章生成器
前几天,GitHub 有个开源项目特别火,只要输入标题就可以生成一篇长长的文章。 背后实现代码一定很复杂吧,里面一定有很多高深莫测的机器学习等复杂算法 不过,当我看了源代码之后 这程序不到50行 尽管我有多年的Python经验,但我竟然一时也没有看懂 当然啦,原作者也说了,这个代码也是在无聊中诞生的,平时撸码是不写中文变量名的, 中文...
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的回答,对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalking,作者吴晟、刘浩杨 等等 仓库地址: apache/skywalking 更...
MySQL数据库总结
一、数据库简介 数据库(Database,DB)是按照数据结构来组织,存储和管理数据的仓库。 典型特征:数据的结构化、数据间的共享、减少数据的冗余度,数据的独立性。 关系型数据库:使用关系模型把数据组织到数据表(table)中。现实世界可以用数据来描述。 主流的关系型数据库产品:Oracle(Oracle)、DB2(IBM)、SQL Server(MS)、MySQL(Oracle)。 数据表:数...
相关热词 c#中dns类 c#合并的excel c# implicit c#怎么保留3个小数点 c# 串口通信、 网络调试助手c# c# 泛型比较大小 c#解压分卷问题 c#启动居中 c# 逻辑或运算符
立即提问