Python打卡第二天

Python打卡第二天

大名鼎鼎的条件和循环结构

条件:如果……那么,突然想起了小学语文课的造句

if expression:
    expr_true_suite
else:
    expr_false_suite

else部分可以没有,也可以在else中再嵌套条件结构。当需要检查多个表达式是否为真时可用elif 语句代替 else if

if expression1:
    expr1_true_suite
elif expression2:
    expr2_true_suite
    .
    .
elif expressionN:
    exprN_true_suite
else:
    expr_false_suite

“断言”: assert,assert后边的条件为 False 时,程序自动崩溃并抛出AssertionError的异常。

循环:当……为真就执行……

while 布尔表达式:
    代码块

当然while和else也可以连用,当……为真就执行……否则……

还有一种循环是遍历循环

for 迭代变量 in 可迭代对象:
    代码块

往往和range() 函数连用,range提供了遍历范围

enumerate()函数起到了for+range组合的作用,同时还能返回序号

break语句可以跳出当前所在层的循环。

continue终止本轮循环并开始下一轮循环。

pass 语句的意思是“不做任何事”,如果你在需要有语句的地方不写任何语句,那么解释器会提示出错,而 pass 语句就是用来解决这些问题的。 (就像玩游戏时说的pass,OK,next one)

列表推导式

鲁迅曾经说过,科学就是用别人听不懂的话说一些东西(鲁迅:我没说过),而列表推导式翻译成人话就是把条件或者循环语句的结果保存在列表里

元组推导式

有了上面的例子,这个就不谈了吧

集合推导式

说实话连推导式这几个字我都懒得打了

嗯,需要说明的是列表[],元组(),集合{}的表示方式

练习:

1、编写一个Python程序来查找那些既可以被7整除又可以被5整除的数字,介于1500和2700之间。

# your code here
for x in range(1500,2701):
	if x % 5 == 0 and x % 7 == 0:
	print x
   
   

2、龟兔赛跑游戏

题目描述:

话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔 子和乌龟的赛跑。他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己领先t米或以 上,它们就会停下来休息s秒。对于不同的兔子,t,s的数值是不同的,但是所有的乌龟却是一致——它们不到终点决不停止。

然而有些比赛相当漫长,全程观看会耗费大量时间,而小华发现只要在每场比赛开始后记录下兔子和乌龟的数据——兔子的速度v1(表示每秒兔子能跑v1 米),乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l——就能预测出比赛的结果。但是小华很懒,不想通过手工计算推测出比赛的结果,于是他找 到了你——清华大学计算机系的高才生——请求帮助,请你写一个程序,对于输入的一场比赛的数据v1,v2,t,s,l,预测该场比赛的结果。

输入:

输入只有一行,包含用空格隔开的五个正整数v1,v2,t,s,l,其中(v1,v2< =100;t< =300;s< =10;l< =10000且为v1,v2的公倍数)

输出:

输出包含两行,第一行输出比赛结果——一个大写字母“T”或“R”或“D”,分别表示乌龟获胜,兔子获胜,或者两者同时到达终点。

第二行输出一个正整数,表示获胜者(或者双方同时)到达终点所耗费的时间(秒数)。


样例输入:

10 5 5 2 20

样例输出

D
4

# your code herelist_1=[]
v1,v2,t,s,l=input("请输入用空格隔开的五个正整数,v1,v2,t,s,l其中(v1,v2< =100;t< =300;s< =10;l< =10000且为v1,v2的公倍数)").split()
list=[v1,v2,t,s,l]
for i in list: 
    list_1.append(data)
v_1,v_2,add,ts,lu=list_1   
tt=lu/v_2  
t_2=0
t_1=0
lu_1=0
flag=1
while flag:
    t_1 = t_1+1
    t_2 = t_2 + 1
    lu_1 = t_2 * v_1
    if lu_1 >= lu:
        flag=0
    elif (lu_1-t_2*v_2)>=add:
        t_1=t_1+ts
if t_1 > tt:   
    print("T")
    print(tt)
elif t_1 < tt:
    print("R")
    print(t_1)
else:
    print("D")
    print(t_1)


   

猜你喜欢

转载自blog.csdn.net/sinat_39470268/article/details/107550008