Python【每日一问】23
问:
【基础题】:判断 101-200 之间有多少个素数,并输出所有素数
PS:素数:一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数
【提高题】:输入某年某月某日,判断这一天是周几?(不能用库)
答:
【基础题】:判断 101-200 之间有多少个素数,并输出所有素数
PS:素数:一个大于1的自然数,除了1和它自身外,不能被其他自然数整除的数
方法1:
prime_number_list = []
for i in range(101, 201):
for j in range(2, int(i**0.5)+1):
if i % j == 0:
break
else:
prime_number_list.append(i)
print("101-200之间的素数有:{}个".format(len(prime_number_list)))
print(prime_number_list)
方法2:
'''
求100到200以内的素数
''' prime_number_list = [2]
for i in range(3, 201):
for prime_number in prime_number_list:
if i % prime_number == 0:
break
else:
prime_number_list.append(i) filtered_prime_number_list = list(filter(lambda x: x>= 101, prime_number_list)) print(filtered_prime_number_list)
输出结果:
[101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]
【提高题】:输入某年某月某日,判断这一天是周几?(不能用库)
import re # 1582年10月15是周六 class calen:
def __init__(self, year, month, day):
self.Year = year
self.Month = month
self.Day = day
self.other = 16 + 30 + 31
'''
1582年以前各国日历计算不太一样,
所以1582年以前一年不知道多少天,345天都有可能。
因此直接从1583年算起的,1582.10.15到1582.12.31一共 self.other 天
''' # 判断闰年
def is_leap_year(self, year):
if (year % 400 == 0) or (year % 100 != 0 and year % 4 == 0):
return 366
else:
return 365 def week(self):
weekdays = ["星期一", "星期二", "星期三", "星期四", "星期五", "星期六", "星期日"]
monthday = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
# 判断二月
if self.is_leap_year(self.Year) == 366:
monthday[1] = 29
day_sum = 0
# 判断年数
for y_year in range(1583, self.Year):
if self.is_leap_year(y_year) == 366:
day_sum += 366
else:
day_sum += 365 # 判断月数
for m_month in range(self.Month - 1):
day_sum += monthday[m_month] # 天数
day_sum += self.Day weekday = (day_sum - self.other - 10) % 7
print("这一天是{}".format(weekdays[weekday])) if __name__ == "__main__":
input_date = input('请输入日期(年-月-日):')
year_number, month_number, day_number = map(int, re.findall(r'\d+', input_date))
w = calen(year_number, month_number, day_number)
w.week()
输出结果:
Python【每日一问】23的更多相关文章
- [python每日一练]--0012:敏感词过滤 type2
题目链接:https://github.com/Show-Me-the-Code/show-me-the-code代码github链接:https://github.com/wjsaya/python ...
- Python 每日一练 | Flask 实现半成品留言板
留言板Flask实现 引言 看了几天网上的代码,终于写出来一个半成品的Flask的留言板项目,为什么说是半成品呢?因为没能实现留言板那种及时评论刷新的效果,可能还是在重定向上有问题 或者渲染写的存在问 ...
- Python每日一练(1):计算文件夹内各个文章中出现次数最多的单词
#coding:utf-8 import os,re path = 'test' files = os.listdir(path) def count_word(words): dic = {} ma ...
- python每日一函数 - divmod数字处理函数
python每日一函数 - divmod数字处理函数 divmod(a,b)函数 中文说明: divmod(a,b)方法返回的是a//b(除法取整)以及a对b的余数 返回结果类型为tuple 参数: ...
- 每日一问:Android 消息机制,我有必要再讲一次!
坚持原创日更,短平快的 Android 进阶系列,敬请直接在微信公众号搜索:nanchen,直接关注并设为星标,精彩不容错过. 我 17 年的 面试系列,曾写过一篇名为:Android 面试(五):探 ...
- 每日一问:谈谈 volatile 关键字
这是 wanAndroid 每日一问中的一道题,下面我们来尝试解答一下. 讲讲并发专题 volatile,synchronize,CAS,happens before, lost wake up 为了 ...
- 每日一问:讲讲 Java 虚拟机的垃圾回收
昨天我们用比较精简的文字讲了 Java 虚拟机结构,没看过的可以直接从这里查看: 每日一问:你了解 Java 虚拟机结构么? 今天我们必须来看看 Java 虚拟机的垃圾回收算法是怎样的.不过在开始之前 ...
- 每日一问:你了解 Java 虚拟机结构么?
对于从事 C/C++ 程序员开发的小伙伴来说,在内存管理领域非常头疼,因为他们总是需要对每一个 new 操作去写配对的 delete/free 代码.而对于我们 Android 乃至 Java 程序员 ...
- 每日一问:LayoutParams 你知道多少?
前面的文章中着重讲解了 View 的测量流程.其中我提到了一句非常重要的话:View 的测量匡高是由父控件的 MeasureSpec 和 View 自身的 `LayoutParams 共同决定的.我们 ...
- 每日一问:简述 View 的绘制流程
Android 开发中经常需要用一些自定义 View 去满足产品和设计的脑洞,所以 View 的绘制流程至关重要.网上目前有非常多这方面的资料,但最好的方式还是直接跟着源码进行解读,每日一问系列一直追 ...
随机推荐
- ASP.NET Core 应用程序状态
在ASP.NET Core中,由多种途径可以对应用程序状态进行管理,使用哪种途径,由检索状态的时机和方式决定. 应用程序状态指的是用于描述当前状况的任意数据.包括全局和用户特有的数据. 开发人员可以根 ...
- Haskell路线
@ 知乎 @ <I wish i have learned haskell> ———— 包括: Ranks, forall, Monad/CPS, monadic parser, FFI ...
- Jquery实现左右轮播效果
首先展示下静态布局h5代码,代码非常简单. <div id="slide"> <ul class="pic-list"> <li& ...
- flex:1和flex:auto详解
flex:1和flex:auto详解 首先明确一点是, flex 是 flex-grow.flex-shrink.flex-basis的缩写. flex-grow属性定义项目的放大比例,默认为0,即如 ...
- 如何开启telnet服务LINUX&Windows
一.LINUX centos 1.Linux安装telnet包 # yum install telnet* # rpm -qa |grep telnet telnet-server-0.17-47.e ...
- Two-Stream Adaptive Graph Convolutional Network for Skeleton-Based Action Recognition
Two-Stream Adaptive Graph Convolutional Network for Skeleton-Based Action Recognition 摘要 基于骨架的动作识别因为 ...
- Sigmoid函数与Softmax函数的理解
1. Sigmod 函数 1.1 函数性质以及优点 其实logistic函数也就是经常说的sigmoid函数,它的几何形状也就是一条sigmoid曲线(S型曲线). 其中z ...
- Java八大排序之基数排序
基数排序(radix sort)属于“分配式排序”(distribution sort),又称“桶子法”(bucket sort)或bin sort,顾名思义,它是透过键值的部份资讯,将要排序的元素分 ...
- Peekaboo(2019年上海网络赛K题+圆上整点)
目录 题目链接 题意 思路 代码 题目链接 传送门 题意 你的位置在\(O(0,0)\),\(A\)的位置为\((x_1,y_1)\),\(B\)的位置为\((x_2,y_2)\),现在已知\(a=O ...
- Make Rounddog Happy(2019年杭电多校第十场1011+HDU6701+启发式分治)
目录 题目链接 题意 思路 代码 题目链接 传送门 题意 求有多少个子区间满足\(a_l,a_{l+1},\dots,a_r\)均不相同且\(max(a_l,a_{l+1},\dots,a_r)-(r ...