第一题:使用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-作业的更多相关文章

  1. 铁乐学Python_day12_作业

    1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...

  2. 铁乐学python_day10_作业

    1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...

  3. 铁乐学python_day09_作业

    练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...

  4. 铁乐学Python_day08作业

    1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数. apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过 ...

  5. 铁乐学python_Day44_IO多路复用

    目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...

  6. 铁乐学python_Day43_协程

    铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...

  7. 铁乐学python_Day42_线程池

    铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...

  8. 铁乐学python_Day42_线程-信号量事件条件

    铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...

  9. 铁乐学python_Day42_锁和队列

    铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...

  10. 铁乐学python_Day39_多进程和multiprocess模块2

    铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...

随机推荐

  1. no awt in java.libary.path

    缺少依赖包. linux下进入jdk安装路径/jre/lib/i386 使用ldd查看依赖包情况: ldd libawt.so 如果发现有not found的,就安装上,或者从jdk下查找,使用软连接 ...

  2. CentOS install搭建SVN服务器

    安装步骤如下: 1.命令:yum install subversion 之后会打印很多消息,显示 Complete! 则完成. 2.查看 svn 版本:svnserve --version 3.创建S ...

  3. Maven 添加 Tomcat 插件

    若想在 Maven 中使用 Tomcat 服务器,需要在 pom.xml 文件中的 <build></build> 标签中添加以下代码 <!-- Maven项目编译插件 ...

  4. Spark2.3.1中用各种模式来跑官方Demo

    1  使用单机local模式提交任务 local模式也就是本地模式,也就是在本地机器上单机执行程序.使用这个模式的话,并不需要启动Hadoop集群,也不需要启动Spark集群,只要有一台机器上安装了J ...

  5. 功能------常用快捷键(在win10下)

    功能------win10 常用快捷键 在进行学习,记录,编写代码时,需要用到一些功能,用鼠标浪费时间,可以使用快捷键来快速的处理.方便操作. 以下内容分为两类.快捷键以及触控板类(不能享用鼠标) 快 ...

  6. HA_Snapshots 数据库快照

    1. 创建测试数据库HA_Snapshot 2. 创建快照 create database HA_Snapshot_20 on ( name = HA_Snapshot, filename = '.. ...

  7. vue常见知识点整理

    什么是 mvvm? MVVM 是 Model-View-ViewModel 的缩写.mvvm 是一种设计思想.Model 层代表数据模型,也可以在 Model 中定义数据修改和操作的业务逻辑:View ...

  8. PHP中常用的魔术方法

    我们在PHP中经常用到魔术方法,像构造方法,析构方法等等魔术变量,下面总结一下一些常用的魔术变量: __construct(),__destruct(),__clone(),__autoload(), ...

  9. UVAlive6800The Mountain of Gold?(负环)

    题意 题目链接 问从\(0\)出发能否回到\(0\)且边权为负 Sol 先用某B姓算法找到负环,再判一下负环上的点能否到\(0\) #include<bits/stdc++.h> #def ...

  10. linux解压tar.gz

    gnuzip或者tar -zxvf file.tar.gz unzip file.zip