日期: 2021 年 4 月 9 日

输入某年某月某日,判断这一天是这一年的第几天?

Python练习题——输入某年某月某日,判断这一天是这一年的第几天?

输入某年某月某日,判断这一天是这一年的第几天?

程序分析:以2020年3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,2020年是闰年且输入月份大于2时需考虑多加一天:

 

time_date = input(“请按’19110101‘格式,输入年月日:”)
year,month,day = int(time_date[:4]),int(time_date[4:6]),int(time_date[6:8]) #将输入的数字拆分

month_set = [31,28,31,30,31,30,31,31,30,31,30,31] #12个月的天数

if 0 < month < 12 and 0 < day < 32: #判断月日输入的正确与否
print(‘你输入的日期格式正确’)
else:
print(‘你输入的日期格式不正确,请重新输入’)

if (year % 400 == 0) or (year % 4 == 0) and (year % 100 != 0) and (month > 2): #判断是否为闰年且输入月份是否大于2
d_sum = 1
else:
d_sum = 0

i = 0
for i in range(month – 1): #遍历完整月份天数
if i < (month – 1):
d_sum += month_set[i] #将完整月份天数求和
i += 1

d_sum += day #完整月份天数求和后,在加上day

print(“%d年%d月%d日是这一年的第%d天”%(year,month,day,d_sum))
执行结果:

请按’19110101‘格式,输入年月日:20200226
你输入的日期格式正确
2020年2月26日是这一年的第57天

龟兔赛跑预测

龟兔赛跑预测

基础试题VIP:龟兔赛跑预测
问题描述
话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。
于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。
他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己*t米或以上,它们就会停下来休息s秒。
对于不同的兔子,t,s的数值是不同的,但是所有的乌龟却是一致——它们不到终点决不停止。
然而有些比赛相当漫长,全程观看会耗费大量时间,而小华发现只要在每场比赛开始后记录下兔子和乌龟的数据——
兔子的速度v1(表示每秒兔子能跑v1米),乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l——就
能预测出比赛的结果。但是小华很懒,不想通过手工计算推测出比赛的结果,于是他找到了你——清华大学计算机系的高才生——请求帮助,请你写一个程序,
对于输入的一场比赛的数据v1,v2,t,s,l,预测该场比赛的结果。
输入格式
输入只有一行,包含用空格隔开的五个正整数v1,v2,t,s,l,其中(v1,v2<=100;t<=300;s<=10;l<=10000且为v1,v2的公倍数)
输出格式
输出包含两行,*行输出比赛结果——一个大写字母“T”或“R”或“D”,分别表示乌龟获胜,兔子获胜,或者两者同时到达终点。
第二行输出一个正整数,表示获胜者(或者双方同时)到达终点所耗费的时间(秒数)。
样例输入
10 5 5 2 20
样例输出
D
4
样例输入
10 5 5 1 20
样例输出
R
3
样例输入
10 5 5 3 20
样例输出
T
4

要把兔子休息的时间和跑步的时间分离开来
兔子跑步的时间也就是乌龟走路的时间。
这个时间以秒为单位,所以以秒为循环就好了,为什么?
题目暗示了,你细品。

#v1兔子速度、v2乌龟速度、t兔子超过距离、s停下秒数、l赛道长度
v1,v2,t,s,l=map(int,input().split(” “))

turtle_time=l/v2 #乌龟走完整个路程所用时间
rabbit_run_time=0 #除去休息以外花费的时间
rabbit_rest_time=0 #休息花费的时间
while True:
rabbit_run_time=rabbit_run_time+1 #时间流逝

rabbit_l=rabbit_run_time*v1 #兔子走过的路程
turtle_l=(rabbit_run_time+rabbit_rest_time)*v2 #乌龟走过的路程

if rabbit_l>=l or turtle_l>=l: #如果路程被乌龟和兔子任意一个人走完
if rabbit_rest_time+rabbit_run_time>turtle_time:
print(“T”)
print(int(turtle_time))
elif rabbit_rest_time+rabbit_run_time<turtle_time:
print(“R”)
print(int(rabbit_rest_time+rabbit_run_time))
else:
print(“D”)
print(int(turtle_time))
break
if rabbit_l-turtle_l>=t and rabbit_l<=l: #给兔子加时
rabbit_rest_time=rabbit_rest_time+s

注意加时和判断走完的顺序,只要兔子或者乌龟走完了就不能加时

区间K大数查询(Python)

区间K大数查询(Python)

题目
问题描述
给定一个序列,每次询问序列中第l个数到第r个数中第K大的数是哪个。

输入格式
*行包含一个数n,表示序列长度。

第二行包含n个正整数,表示给定的序列。

第三个包含一个正整数m,表示询问个数。

接下来m行,每行三个数l,r,K,表示询问序列从左往右第l个数到第r个数中,从大往小第K大的数是哪个。序列元素从1开始标号。

输出格式
总共输出m行,每行一个数,表示询问的答案。
样例输入
5
1 2 3 4 5
2
1 5 2
2 3 2
样例输出
4
2
数据规模与约定
对于30%的数据,n,m<=100;

对于100%的数据,n,m<=1000;

保证k<=(r-l+1),序列中的数<=106。

题目很简单,但是有坑点

%title插图%num

这个数组后面有个空格
所以你要除去它

#用于寻找K值的函数
def outputnumber(l1,l2):
l=[]
for i in range(l2[0]-1,l2[1]):
l.append(l1[i])
l.sort(reverse=True)
k=l2[2]-1
print(l[k])
#删除*后一个空格并转换成数组
n=int(input())
l1=list(map(str,input().split(” “)))
l1.pop()
for i in range(len(l1)):
l1[i]=int(l1[i])
#将数据存在二维数组方便遍历输出
m=int(input())
ls=[[] for i in range(m)]
for i in range(m):
ls[i] = list(map(int, input().split(” “)))
#输出
for i in range(m):
outputnumber(l1,ls[i])

 

蛇形取数 纯数学手算高效快速解法

蛇形取数 纯数学手算高效快速解法

题目

%title插图%num
解题方法
本着填空题能不写代码就不写代码的理念
思考良久发现这种题目可以用数学方法简单快速高效得解出来
先看这些数据

%title插图%num

把每一个黄色填充的数据(即a[i][i])都看成是直角三角形的斜边上的中点。

对于第2行第2列的值为5:是边长为3的等腰直角三角形的斜边上的中点。这个等腰直角三角形的面积是4.5。
对于第3行第3列的值为13:是边长为5的等腰直角三角形的斜边上的中点。这个等腰直角三角形的面积是12.5。
对于第4行第4列的值为25:是边长为7的等腰直角三角形的斜边上的中点。这个等腰直角三角形的面积是24.5。
对于第5行第5列的值为41:是边长为9的等腰直角三角形的斜边上的中点。这个等腰直角三角形的面积是40.5。
对于第6行第6列的值为61:是边长为11的等腰直角三角形的斜边上的中点。这个等腰直角三角形的面积是60.5。
……………………
所以规律很明显嘛,第n行第n列的值就是以边长为2n-1的等腰直角三角形面积的四舍五入

所以第20行第20列的值为:
39*39/2=760.5 四舍五入 为761

Python 确定字符串是否是另一个的排列

Python 确定字符串是否是另一个的排列(sorted用法)

题目
确定字符串是否是另一个的排列。
实现一个算法来识别一个字符串 str2 是否是另一个字符串 str1 的排列。排列的解释如下:
如果将 str1 的字符拆分开,重新排列后再拼接起来,能够得到 str2 ,那么就说字符串 str2 是字符串 str1 的排列。

笨蛋方法
就是我了

def is_permutation( str1, str2):
if len(str1) == len(str2) and str1 is not None and str2 is not None:
for i in str1:
if i not in str2:
return 1
return 2
else:
return 1

a=input()
b=input()
s=is_permutation(a,b)
print(s)

傻傻得遍历循环

高级做法
def permutation(str1, str2):
if str1 is None or str2 is None:
return False
return sorted(str1) == sorted(str2)

使用排序,能够“排列”的排序之后必定是一样的。

def sorted(*args, **kwargs): # real signature unknown
“””
Return a new list containing all items from the iterable in ascending order.
返回一个新的列表,从小到大有序排列
A custom key function can be supplied to customize the sort order, and the
reverse flag can be set to request the result in descending order.
也可以自己设置reverse的值让它从大到小排列
“””
pass

Python试题:门牌制作

Python试题:门牌制作

题目

%title插图%num
代码
count=0

for i in range(1,2021):
l=list(str(i))
for i in l:
if i==’2′:
count=count+1
print(count)

#624

解释
从1遍历到2020,
我们把每次遍历的时候的数字拆开
只要遇到2就让计数器加一即可
答案是624

 

蓝桥杯Python组:跑步锻炼

蓝桥杯Python组:跑步锻炼

题目

%title插图%num
代码
#2000.1.1(6)-2020.10.1(4)
#年、月、日、周、计数
year=2000
mouth=1
day=1
week=6
count=0
mouthday=[0,31,28,31,30,31,30,31,31,30,31,30,31] #月份对齐索引标号所以以0开始

#闰年判断
def runnian(year):
if year%4==0 and year%100!=0:
return True
elif year%400==0:
return True
else:
return False

while year!=2020 or mouth!=10 or day!=1:
#修改当前年份二月的day数
if runnian(year):
mouthday[2]=29
else:
mouthday[2]=28

day=day+1

week=(week+1)%7 #算好星期几,因为天数加一了,这个星期也要加一

#如果大于当前的月份所对应的day数,就让月份加一,并且将day置为0
if day>mouthday[mouth]:
day=1
mouth+=1
#对月份和年份进行增值
if mouth>12:
mouth=1
year+=1
#月初或者周一
if day==1 or week==1:
count+=1

count+=1

#上来就将day+=1了,并没有算*开始的日子
count+=2
print(count)

我的解题过程(经验)
一开始总想着用Excel能够搞出来,浪费了很多时间
其实这个一点也不难
难得是不能脚踏实地得去解题
总想着另辟蹊径

 

Android OKHttp 获取服务器的 Json 数据,没有双引号?

我服务器使用 SpringBoot 写的,如下:

    @GetMapping(value = "/GetImageByUser",produces = "application/json;charset=UTF-8")
    @ApiOperation("获取用户图片,每个分类前 100 张")
    @ApiImplicitParams({
            @ApiImplicitParam(name = "userId", value = "userId", dataType = "String", paramType = "query")
    }
    )
    public Result getImageByUser(String userId) {
        return imageService.getImageByUser(userId);
    }

返回值 Result 对象如下:

public class Result {
    private int code;
    private boolean message;
    private Object detail;
    ...省略 setter 和 getter 方法
}

然后在浏览器访问这个接口的时候,响应结果是带双引号的:

{"code":200,"message":true,"detail":[{"category":{"objectId":"0c0a0ddaa1b84ce286be4343cd9d3438","categoryId":"c5341c1d8ac547589899514516d0768a","categoryName":"WeiXin","categoryUser":"84f6e0d8d94348ccab981e364661a419","isPrivate":-1,"categoryStatus":1,"createTime":3},"images":[{"objectId":"f6d97d24556348a4ac342cb321397718","imageId":"e50ba0a75359432f89390d85daefb10a","sha1":"c3063275501e0f8ef87703473c7263168771f21b","fileCategory":"c5341c1d8ac5475898
省略...

然后使用 Swagger 做调试的时候也是同样的效果。

但是在 Android 端使用 OKHttp 访问接口的时候,json 的 key 和 value 都不带双引号:

[{category={objectId=0c0a0ddaa1b84ce286be4343cd9d3438, categoryId=c5341c1d8ac547589899514516d0768a, categoryName=WeiXin, categoryUser=84f6e0d8d94348ccab981e364661a419, isPrivate=-1.0, categoryStatus=1.0, createTime=3.0}, images=[{objectId=f6d97d24556348a4ac342cb321397718, imageId=e50ba0a75359432f89390d85daefb10a, sha1=c3063275501e0f8ef87703473c7263168771f21b, 
省略...

因为 json 中有时候会含有网址,所以在解析 JSON 的时候就会出错。

我感觉问题应该是出在 OKHttp 上,因为在浏览器是正常的(带双引号),使用 swagger 调试接口的时候也是正常的

请问这个问题该如何解决啊?如何让 key 和 value 中的字符串都是带双引号的呢?

14 条回复
grantonzhuang
    1

grantonzhuang   73 天前

你这打印的不是 json,是 toString 方法打印出来的
w292614191
    2

w292614191   73 天前

OKHttp 可不会出这种低级错误。
qwerthhusn
    3

qwerthhusn   73 天前

目测 lz 新人,这个 JSON 已经反序列化成对象了,打印的是 toString 又不是 json
beichenhpy
    4

beichenhpy   73 天前

访问接口这个打出来的已经是反序列化的对象了,自然没有引号
Helsing
    5

Helsing   73 天前 via iPhone

找一个可以打印 json 的库,xlog 、logger 之类的
hongch
    6

hongch   73 天前

response.body.string 就是带双引号的
kingfalse
    7

kingfalse   73 天前 via Android

okhttp 直呼内行并表示你还是换个 HTTP 请求库吧
yinzhili
    8

yinzhili   73 天前

楼主需要补一补基础知识了
Paaranoia
    9

Paaranoia   73 天前

建议看看 okhttp 的文档
scxiazi
    10

scxiazi   73 天前

这打印的是对象

amok
    11

amok   73 天前

应该只是打印的问题,看看打印的代码是怎么写的,是否打印的 toString ?这里应该用拦截器打印 http 报文。
Vegetable
    12

Vegetable   73 天前   ❤️ 2

还建议看 okhttp 文档呢?这显然是需要重学 java 啊
lychs1998
    13

lychs1998   73 天前

这是 toString 出来的结果吧。看看有没有实体类自己输出 jsonStr 的方法。
unco020511
    14

unco020511   73 天前

你这是对象的 toSting(),不是 json

更改视频播放速度 Python/Opencv

更改视频播放速度 Python/Opencv

功能
根据更改原始视频的播放速度并保存更改视频
可指定fps,也可指定播放倍速,两者同时指定时,以fps为主

依赖库
python3,cv2

代码实现
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time : 2021/04/08
# @Author : Devil_Xiao
# Purpose: This script is used to change the video_speed
# You can choose to specify the fps,
# or you can choose to change the multiple of the original playback speed

import cv2
from cv2 import VideoWriter, VideoWriter_fourcc
import argparse

def video_speed(video_root, out_root, fps=None, scale=1):
“””When fps and scale are specified at the same time, fps is the dominant”””
cap = cv2.VideoCapture(video_root)
video_width = int(cap.get(3))
video_height = int(cap.get(4))
fourcc = cv2.VideoWriter_fourcc(‘m’, ‘p’, ‘4’, ‘v’)
if fps:
videoWriter = cv2.VideoWriter(out_root, fourcc, fps, (video_width, video_height))
else:
fps = int(cap.get(cv2.CAP_PROP_FPS) * scale)
videoWriter = cv2.VideoWriter(out_root, fourcc, fps, (video_width, video_height))
flag = cap.isOpened()

while (flag):
flag, frame = cap.read()
videoWriter.write(frame)
videoWriter.release()

if __name__ == ‘__main__’:
parser = argparse.ArgumentParser()
parser.add_argument(‘–video_name’, type=str, default=r’video.mp4′, help=’original video name’)
parser.add_argument(‘–result_name’, type=str, default=r’result.mp4′, help=’result name’)
parser.add_argument(‘–fps’, type=int, default=None, help=’Specify the playback frame rate’)
parser.add_argument(‘–scale’, type=float, default=’0.5′, help=’Change the original video speed’)
opt = parser.parse_args()
print(opt)
video_speed(opt.video_name, opt.result_name, opt.fps, opt.scale)

Mac os big sur 的「照片」应用不支持在隔空投送传输照片时候包含「所有照片数据」?

前 10.15 时候,将 mac 照片应用里修改后的照片通过隔空投送传输到 iPhone 或者 iPad 上,是自动包含原始照片数据的。也就是说,mac 上修改的照片,传输到 iPhone 上是可以复原成原始照片的,现在这个功能没有了。
但是 iPhone 之间通过隔空投送传输照片,依然提供包含「所有照片数据」选项,太魔性了,是不是 mac os 将这个选项隐藏起来了?还是得配合快捷键使用?

2 条回复    2021-03-20 22:01:59 +08:00

zhaidoudou123
    1

zhaidoudou123   19 天前

刚刚试了一下,确实有这个问题
tomjerry27
    2

tomjerry27   19 天前

@zhaidoudou123 打了苹果的技术支持电话,他们也不清楚说会帮我反馈
友情链接: SITEMAP | 旋风加速器官网 | 旋风软件中心 | textarea | 黑洞加速器 | jiaohess | 老王加速器 | 烧饼哥加速器 | 小蓝鸟 | tiktok加速器 | 旋风加速度器 | 旋风加速 | quickq加速器 | 飞驰加速器 | 飞鸟加速器 | 狗急加速器 | hammer加速器 | trafficace | 原子加速器 | 葫芦加速器 | 麦旋风 | 油管加速器 | anycastly | INS加速器 | INS加速器免费版 | 免费vqn加速外网 | 旋风加速器 | 快橙加速器 | 啊哈加速器 | 迷雾通 | 优途加速器 | 海外播 | 坚果加速器 | 海外vqn加速 | 蘑菇加速器 | 毛豆加速器 | 接码平台 | 接码S | 西柚加速器 | 快柠檬加速器 | 黑洞加速 | falemon | 快橙加速器 | anycast加速器 | ibaidu | moneytreeblog | 坚果加速器 | 派币加速器 | 飞鸟加速器 | 毛豆APP | PIKPAK | 安卓vqn免费 | 一元机场加速器 | 一元机场 | 老王加速器 | 黑洞加速器 | 白石山 | 小牛加速器 | 黑洞加速 | 迷雾通官网 | 迷雾通 | 迷雾通加速器 | 十大免费加速神器 | 猎豹加速器 | 蚂蚁加速器 | 坚果加速器 | 黑洞加速 | 银河加速器 | 猎豹加速器 | 海鸥加速器 | 芒果加速器 | 小牛加速器 | 极光加速器 | 黑洞加速 | movabletype中文网 | 猎豹加速器官网 | 烧饼哥加速器官网 | 旋风加速器度器 | 哔咔漫画 | PicACG | 雷霆加速