|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
本帖最后由 四君子 于 2018-1-1 23:11 编辑
动动手的题目:有一个长阶梯,若每步上2阶,最后剩1阶;若每步上3阶,最后剩2阶;若每步上5阶,最后剩4阶;若每步上6阶,最后剩5阶;只有每步上7阶,最后刚好一阶也不剩。请编程求解该阶梯至少有多少阶?
我的第一次写的代码是这样,可以求出梯子最少的阶
- n = 0 #阶梯从0开始累加计算
- a = 1
- while a:
- if (n-1)%2 == (n-2)%3 == (n-4)%5 == (n-5)%6 == n%7 == 0: #满足全部余数都为0的条件
- print('此梯子至少有',n,'阶')
- a -= 1 #求出最少值后退出循环
- n += 1
复制代码
但是我尝试下用逻辑运算符的方式求解,代码如下,运行后就没反应了,也没有报错,求大神分析:
- n = 0
- a = 1
- while a==1:
- if isinstance(((n-1)/2),int) and isinstance(((n-2)/3),int) and isinstance(((n-4)/5),int) and isinstance(((n-5)/6),int) and isinstance((n/7),int):
- print('此梯子最少有:',n,'阶')
- a -= 1
- n += 1
复制代码
因为3.x以后的版本直接除得到的类型都是float
- >>> a = 4/2
- >>> type(a)
- <class 'float'>
复制代码
|
|