问:

【基础题】:判断 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的更多相关文章

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

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

  2. Python 每日一练 | Flask 实现半成品留言板

    留言板Flask实现 引言 看了几天网上的代码,终于写出来一个半成品的Flask的留言板项目,为什么说是半成品呢?因为没能实现留言板那种及时评论刷新的效果,可能还是在重定向上有问题 或者渲染写的存在问 ...

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

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

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

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

  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. ASP.NET Core 应用程序状态

    在ASP.NET Core中,由多种途径可以对应用程序状态进行管理,使用哪种途径,由检索状态的时机和方式决定. 应用程序状态指的是用于描述当前状况的任意数据.包括全局和用户特有的数据. 开发人员可以根 ...

  2. Haskell路线

    @ 知乎 @ <I wish i have learned haskell> ———— 包括: Ranks, forall, Monad/CPS,  monadic parser, FFI ...

  3. Jquery实现左右轮播效果

    首先展示下静态布局h5代码,代码非常简单. <div id="slide"> <ul class="pic-list"> <li& ...

  4. flex:1和flex:auto详解

    flex:1和flex:auto详解 首先明确一点是, flex 是 flex-grow.flex-shrink.flex-basis的缩写. flex-grow属性定义项目的放大比例,默认为0,即如 ...

  5. 如何开启telnet服务LINUX&Windows

    一.LINUX centos 1.Linux安装telnet包 # yum install telnet* # rpm -qa |grep telnet telnet-server-0.17-47.e ...

  6. Two-Stream Adaptive Graph Convolutional Network for Skeleton-Based Action Recognition

    Two-Stream Adaptive Graph Convolutional Network for Skeleton-Based Action Recognition 摘要 基于骨架的动作识别因为 ...

  7. Sigmoid函数与Softmax函数的理解

    1. Sigmod 函数 1.1 函数性质以及优点 其实logistic函数也就是经常说的sigmoid函数,它的几何形状也就是一条sigmoid曲线(S型曲线).               其中z ...

  8. Java八大排序之基数排序

    基数排序(radix sort)属于“分配式排序”(distribution sort),又称“桶子法”(bucket sort)或bin sort,顾名思义,它是透过键值的部份资讯,将要排序的元素分 ...

  9. Peekaboo(2019年上海网络赛K题+圆上整点)

    目录 题目链接 题意 思路 代码 题目链接 传送门 题意 你的位置在\(O(0,0)\),\(A\)的位置为\((x_1,y_1)\),\(B\)的位置为\((x_2,y_2)\),现在已知\(a=O ...

  10. Make Rounddog Happy(2019年杭电多校第十场1011+HDU6701+启发式分治)

    目录 题目链接 题意 思路 代码 题目链接 传送门 题意 求有多少个子区间满足\(a_l,a_{l+1},\dots,a_r\)均不相同且\(max(a_l,a_{l+1},\dots,a_r)-(r ...