铁乐学python_day01-作业
第一题:使用while循环输入 1 2 3 4 5 6 8 9 10
# 使用while循环输入 1 2 3 4 5 6 8 9 10
count = 0
while (True) :
count = count + 1
#判断当count等于7的时候,返回循环最初,不执行下面的打印等语句
if count == 7:
continue
print (count)
#判断当count等于10的时候,跳出循环。
if count == 10:
break
思路是设置一个初始值count,然后开始循环,自增1;
加if判断语句,当count为7时使用continue跳过打印7;
当count为10时,使用break中断和跳出循环。
敲的时候出了很多规范性的错,
比如没有使用英文的冒号,
没有对应缩进区块,
== 错敲成了=,这两者的区别,
前者是比较值,后者是直接赋值。
更优雅的写法应该是while的同时将其中满足跳出循环的条件也给上,节省代码行数,也比较优雅易懂。
例如以下:
#计数初始为0
count = 0
#当count小于10时,进行循环,反之则是中止循环,不需要用到break
while ( count < 10 ) :
count = count + 1
#当count为7时使用continue跳过打印7;
if count == 7:
continue
print (count)
对比两例可看出,有效代码行数从8行节省到6行,关键是易读性提高了。
第二题:求1-100的所有数的和
# 求1-100的所有数的和
# 求和,故除设置初始计数的count变量外,还应设置多一个sum和的变量
count = 0
sum = 0
# 注意,设置满足的条件我最初设的是小于101,结果得数把101也算进去了,
# 排查后发现是count自增1,到count为99的时候再加1就是100了,条件设为小于100才是刚刚好。
while (count < 100):
#计数器自增1
count = count + 1
#和数和计数器相加
sum = sum + count
#循环中止的时候我们输出结果,注意字符串只能和字符串拼接,所以sum要用str转义
print ('1-100的所有数之和为:'+str(sum))

第三题 输出 1-100 内的所有奇数
odd = 1
while (odd < 101):
print (odd)
#奇数的特质之一是从1开始,自身加2后的数同样也是奇数
odd = odd + 2
如果换另一种思路,从奇数的另一个特质,被2除后都余1来输出的话会怎么样呢?
odd = 0
while (odd < 100):
odd = odd + 1
#取余来进行判断,余数为1则输出打印,不用对余数为0的情况再进行判断。
if (odd % 2 == 1) :
print (odd)
注意,上面敲代码的时候我缩进的时候混合使用了tab键和spaces键以致报错。
所以python在对缩进规范这里要求挺严的,嗯,要优雅,不要慌乱。
第四题:输出1-100内的所有偶数
# 输出 1-100 内的所有偶数
even = 0
while (even < 100):
even = even + 1
#对even进行取余运算,等于0的则打印输出even
if even % 2 == 0:
print (even)
这题与第三题是同类型的,不多作叙述。
第五题:求1-2+3-4+5 ... 99的所有数的和
# 求1-2+3-4+5 ... 99的所有数的和
# 计数器初始为0,和也初始为0
count = 0
sum = 0
while (count < 99):
count = count + 1
#当count是偶数时(取余为0)就被和相减
if count % 2 == 0:
sum = sum - count
#加上continue来控制它不再执行下面的语句,又周而复始进行下一次循环
continue
#反之,奇数时直接相加
sum = sum + count
#别忘了将得出的sum结果输出给用户,str转义成字符串与提示拼接。
print ('1-2+3-4+5...99的所有数的和为:'+str(sum))

第六题:模拟用户登录(三次机会重试)
# 用户登录(三次机会重试)
# 这里题意比较含糊,实际上现在还是基础阶段,
# 老师这题的意思是大致让你模拟出人机交互及认证三次
# 故定义用户名和密码变量如下:
username = 'tiele'
password = 'ABCabc123'
#认证计数器初始为3
count = 3
#开始三次认证循环
while (count > 0):
#开始人机交互,分别输入用户名和密码
name = input ("请输入用户名:")
#需要给个pass让用户进行输入交互
pass
passwd = input ("请输入密码:")
if username == name and password == passwd :
print ("你已成功登录")
#成功登录后当然要break跳出循环
break
else:
#输错机会减1并给出提示
count = count - 1
print ("用户名或密码错误,你还有"+str(count)+"次机会进行验证。")

最初我做这题的时候是用了机会初始为0,增加到3则中止循环的方式,后来对照了一下同学的,感觉的确使用初始机会为3,然后能逐次-1并提示的思路人性化一点。
后来发觉有别的同学用的是我最初的0增到3的思路,直接提示登录失败,到3次时提示超过三次登录失败,请稍后重试,也是很符合常见的情境。
所以是感觉都可以。
至此,day1的作业就全部完成了。
2018-3-17
end
附:day01的作业6题代码全部己提交到github上。
https://github.com/tielemao/python-learn/tree/master/day01
铁乐学python_day01-作业的更多相关文章
- 铁乐学Python_day12_作业
1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...
- 铁乐学python_day10_作业
1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...
- 铁乐学python_day09_作业
练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...
- 铁乐学Python_day08作业
1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数. apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过 ...
- 铁乐学python_Day44_IO多路复用
目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...
- 铁乐学python_Day43_协程
铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...
- 铁乐学python_Day42_线程池
铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...
- 铁乐学python_Day42_线程-信号量事件条件
铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...
- 铁乐学python_Day42_锁和队列
铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...
- 铁乐学python_Day39_多进程和multiprocess模块2
铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...
随机推荐
- Smali 语法文档
可以选择保存成pdf格式,查询起来挺方便的 if v0==0 go cond_0 if-eqz v0, :cond_0 if v0!=0 go cond_0 if-nez v0, :cond_0 ...
- elasticsearch的join查询
1.概述 官方文档 https://www.elastic.co/guide/en/elasticsearch/reference/current/joining-queries.html 两种类型的 ...
- 触摸UITextView找到该触摸点的文字
参加了一个比赛有一道题是如标题一样,在UITextView上触摸找到该触摸点对应的文字,比赛也可以查资料,当时做的时候就是抱着玩玩的心态试试也没认真做,就没查就去吃饭去了,昨晚下班回去在思考这个问题发 ...
- bootstrap table分页,重新数据查询时页码为当前页问题
问题描述: 使用bootstrap table时遇到一个小问题,第一次查询数据未5页,翻页到第5页后,选中条件再次查询数据时,传到后端页码仍旧为5,而此时数据量小于5页,表格显示为未查询到数据. 处理 ...
- HTML的map-area的使用
使用背景 在把设置图转成页面的时候,时常会遇到这种情况:一张小图片上有好多个可以点击的小图标,按常规的处理方法是把这一个一个的小图切出来,然后每个加个a标签进行跳转,但是这样会非常的浪费时间,而且会增 ...
- catch异常
int ret = -1; try { ret = tBuyerCodeApplyInfoService.insertTBuyerCodeApplyInfoBySelective(buyerCode) ...
- IDEA 2019注册码
N757JE0KCT-eyJsaWNlbnNlSWQiOiJONzU3SkUwS0NUIiwibGljZW5zZWVOYW1lIjoid3UgYW5qdW4iLCJhc3NpZ25lZU5hbWUiO ...
- FUzhou 1607 Greedy division---因子个数问题。
Problem 1607 Greedy division http://acm.fzu.edu.cn/problem.php?pid=1607 Accept: 402 Submit: 1463T ...
- Enter键登录
<div class="zhuce_input_ty"> <p><a id="qianlogin" onclick="U ...
- UBuntu安装配置记录
记得是06年左右第一次安装的 Linux,当时是下载的 Fedora镜像,版本已经记不清了,在商业街的电脑维修店刻的盘,回来后兴冲冲地和XP一起安装的双系统.其实就是直接的体验了一把,只是看了看X-W ...