楼主: cyu107
1912 1

[网帖精选] python练习的小技巧 [推广有奖]

  • 4关注
  • 4粉丝

副教授

13%

还不是VIP/贵宾

-

威望
0
论坛币
24652 个
通用积分
11.6801
学术水平
52 点
热心指数
55 点
信用等级
46 点
经验
11550 点
帖子
243
精华
1
在线时间
624 小时
注册时间
2012-11-4
最后登录
2024-7-7

楼主
cyu107 发表于 2014-5-19 13:37:29 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

python练习小技巧

      在学习python中,越来越发现python的方便,也找到了一些python与C/C++的一些相同点与不同点。由于我看的书中缺乏编程练习题,我就在想如何能够尽快地熟悉python。由于我一直在参加算法竞赛,所以就想到了用Python去实现一些数据结构和算法。这类的编程通常不会用到太多的库,但却是锻炼基本功的很好的方法。程序写好后,可以花几分钟实践来总结一下所用到的知识点,这对初学者的效果非常好。下面是书中的一个例子程序,熟悉的八皇后问题,起个抛砖引玉的作用,这段时间我也会用实现一些更复杂的数据结构。


[python]

def conflict(state,nextX):

    nextY=len(state)

    for i in range(nextY):  #注意range是一个半开半闭区间,左闭右开

        if abs(state-nextX) in (0,nextY-i): #这里是python中我很喜欢的一个特性,比同样的C语言代码简单很多。

            return True

    return False


defqueens(num=8,state=()):  #默认参数,与C++的规则一样,从右到左必须都存在默认参数,即如果一个默认参数的右方还存在没有默认值的参数,会出错。

    for pos in range(num):

        if not conflict(state,pos):# if not语句

            if len(state)==num-1:

                 yield (pos,)      #yield生成器,生成tuple,注意(pos,)这样的格式

            else:

                 for result inqueens(num,state+(pos,)):  #tuple等数据结构的连接也是我很喜欢python的一个原因。

                     yield (pos,)+result

defpretty_print(solution):

    def line(pos,length=len(solution)):#函数定义中定义函数,这一点与C/C++都不同,需要额外注意。

        return '.'*pos+'X'+'.'*(length-pos-1)

    for pos in solution:

        print line(pos)

#print list(queens(4))

#print len(list(queens(8)))

import random

pretty_print(random.choice(list(queens(8))))

二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

关键词:python 小技巧 Solution Conflict solutio python是什么 python基础教程 python学习手册

本帖被以下文库推荐

沙发
huangfanchang 发表于 2014-9-2 23:33:54
ding
kankan

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-3 17:12