问:

【基础题1】: 请解释一下 if __name__ == '__main__' :的作用

【基础题2】:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

PS:

Monday        周一
Tuesday 周二
Wednesday 周三
Thursday 周四
Friday 周五
Saturday 周六
Sunday 周日

【提高题】:打印出所有的“水仙花数”

PS:所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如: 153 是一个“水仙花数” ,因为 153=1 的三次方+5 的三次方+3 的三次方

答:

【基础题1】: 请解释一下 if __name__ == '__main__' :的作用

一个python文件有两种使用情况:

(1)直接作为脚本执行
(2)作为module被 import 到其他的 python 脚本中调用执行 if __name__ == 'main': 的作用:当.py文件被直接运行时,if __name__ == '__main__'之下的代码块将被运行;当.py文件以模块形式被导入时,if __name__ == '__main__'之下的代码块不被运行。

if __name__ == '__main__' :起作用的原理:

每个 python 模块都包含内置的变量 __name__,
(1)当 python 模块被直接执行时,__name__ 等于"__main__";
(2)当作为 module 被 import 到其他 python 文件时,则 __name__ 等于模块名称(不包含后缀.py),

因此:
(1)当模块被直接执行时,__name__ == 'main'返回结果为 True
(2)当作为 module 被 import 时,__name__ == 'main'返回结果为 False

【基础题2】:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

方法1:

letter = input("please input:")

if letter == "S":
letter = input("please input second letter:")
if letter == "a":
print("Saturday")
elif letter == "u":
print("Sunday")
else:
print("data error") elif letter == "F":
print("Friday")
elif letter == "M":
print("Monday")
elif letter == "T":
letter = input("please input second letter:")
if letter == "u":
print("Tuesday")
elif letter == "h":
print("Thursday")
else:
print("data error")
elif letter == "W":
print("Wednesday")
else:
print("data error")

方法2:

str = input("请输入第一个字符:\n")

if str is "m" or str is "M":
print("Monday")
elif str is "t" or str is "T":
str1 = input("请输入第二个字符:\n")
if str1 is "u" or str is "U":
print("Tuesday")
elif str1 is "h" or str is "H":
print("Thursday")
elif str is "w" or str is "W":
print("Wednesday")
elif str is "f" or str is "F":
print("Friday")
elif str is "s" or str is "S":
str2 = input("请输入第二个字符:\n")
if str2 is "a" or str is "A":
print("Saturday")
elif str2 is "u" or str is "U":
print("Sunday")

【提高题】:打印出所有的“水仙花数”

PS:所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如: 153 是一个“水仙花数” ,因为 153=1 的三次方+5 的三次方+3 的三次方

方法1:

def PPDI():
for i in range(100,1000):
if i == (i // 100)**3 + (i % 100 // 10)**3 + (i% 100 %10)**3:
print(i) PPDI()

方法2:

for firstNumber in range(1, 10):
for secondNumber in range(10):
for thirdNumber in range(10):
number = firstNumber*100 + secondNumber*10 + thirdNumber
if firstNumber**3 + secondNumber**3 + thirdNumber**3 == number:
print(number)

方法3:

for i in range(100, 1000):
a = int(str(i)[0])
b = int(str(i)[1])
c = int(str(i)[2])
if a ** 3 + b ** 3 + c ** 3 == i:
print(i)

方法4:

def waters():
for i in range(100, 1000):
num = i
result = []
while i > 0:
result.append((i % 10) ** 3)
i = i // 10 if num == sum(result):
print(num, end=" ") if __name__ == "__main__":
waters()

输出结果:

153
370
371
407

Python【每日一问】24的更多相关文章

  1. [python每日一练]--0012:敏感词过滤 type2

    题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...

  2. Python每日一练(1):计算文件夹内各个文章中出现次数最多的单词

    #coding:utf-8 import os,re path = 'test' files = os.listdir(path) def count_word(words): dic = {} ma ...

  3. python每日一函数 - divmod数字处理函数

    python每日一函数 - divmod数字处理函数 divmod(a,b)函数 中文说明: divmod(a,b)方法返回的是a//b(除法取整)以及a对b的余数 返回结果类型为tuple 参数: ...

  4. python socket.error: [Errno 24] Too many open files

    以openwrt AR9331开发板为例,socket连接到1019个就报错 “python socket.error: [Errno 24] Too many open files” 1.查看开发板 ...

  5. 每日一问:Android 消息机制,我有必要再讲一次!

    坚持原创日更,短平快的 Android 进阶系列,敬请直接在微信公众号搜索:nanchen,直接关注并设为星标,精彩不容错过. 我 17 年的 面试系列,曾写过一篇名为:Android 面试(五):探 ...

  6. 每日一问:谈谈 volatile 关键字

    这是 wanAndroid 每日一问中的一道题,下面我们来尝试解答一下. 讲讲并发专题 volatile,synchronize,CAS,happens before, lost wake up 为了 ...

  7. 每日一问:讲讲 Java 虚拟机的垃圾回收

    昨天我们用比较精简的文字讲了 Java 虚拟机结构,没看过的可以直接从这里查看: 每日一问:你了解 Java 虚拟机结构么? 今天我们必须来看看 Java 虚拟机的垃圾回收算法是怎样的.不过在开始之前 ...

  8. 每日一问:你了解 Java 虚拟机结构么?

    对于从事 C/C++ 程序员开发的小伙伴来说,在内存管理领域非常头疼,因为他们总是需要对每一个 new 操作去写配对的 delete/free 代码.而对于我们 Android 乃至 Java 程序员 ...

  9. 每日一问:LayoutParams 你知道多少?

    前面的文章中着重讲解了 View 的测量流程.其中我提到了一句非常重要的话:View 的测量匡高是由父控件的 MeasureSpec 和 View 自身的 `LayoutParams 共同决定的.我们 ...

  10. 每日一问:简述 View 的绘制流程

    Android 开发中经常需要用一些自定义 View 去满足产品和设计的脑洞,所以 View 的绘制流程至关重要.网上目前有非常多这方面的资料,但最好的方式还是直接跟着源码进行解读,每日一问系列一直追 ...

随机推荐

  1. 《EOPL》: 实现了惰性求值的两种参数传递策略

    call-by-need 不过是比 call-by-name 多了一个 memorization 的步骤

  2. 秋招打怪升级之路:十面阿里,终获offer!

    本文转载自:https://gongfukangee.github.io/2019/09/06/Job/ 作者:G.Fukang 开源项目推荐: JavaGuide: Java学习+面试指南!Gith ...

  3. Linq实现字符串拼接多条件查询

    Linq实现字符串拼接多条件查询 开发过程中,为提升用户体验,经常会使用到多条件查询,本篇博客介绍如何使用Linq实现字符串拼接多条件查询 一般SQL字符串拼接 1 string sql = &quo ...

  4. 【转】LockSupport深入浅出

    原文:https://www.cnblogs.com/qingquanzi/p/8228422.html 本篇是<自己动手写把"锁">系列技术铺垫的最后一个知识点.本篇 ...

  5. yum lockfile is held by another process

    使用yum安装软件报错 yum lockfile is held by another process 解决方法 rm -f /var/run/yum.pid

  6. A Comparison of Serverless Frameworks for Kubernetes: OpenFaas, OpenWhisk, Fission, Kubeless and more

    The term Serverless has become synonymous with AWS Lambda. Decoupling from AWS has two benefits; it ...

  7. 安装Vyos

      Vyos是一个开源的网络操作系统,基于Debian,相对于ROS需要购买license,Vyos就更加开放的多. 下载Vyos wget http://vyos.hecint.com/iso/re ...

  8. 关于Visual Studio源代码文件的行尾

    我们都知道,UNIX只使用换行符(linefeed)来结束每一行,而DOS传统上使用CR+LF来结束每一行,Visual Studio应该完全在DOS世界中,但不管出于什么原因,当我们从代码服务器上获 ...

  9. Linux提高工作效率的命令

    find ./ -name 'laun*'|xargs grep 8881 在laun开头的文件内查找8881 find ./ -name 'laun*' find . -type f -mtime ...

  10. <虚树+树型DP> SDOI2011消耗战

    <虚树+树型DP> SDOI2011消耗战 #include <iostream> #include <cstdio> #include <cstring&g ...