python 基础知识点(蓝桥杯python科目个人复习计划63)

今日复习内容:做题

例题1:蓝桥骑士

问题描述:

小蓝是蓝桥王国的骑士,他喜欢不断突破自我。

这天蓝桥国王给他安排了N个对手,他们的战力值分别为a1,a2,...,an,且按顺序阻挡在小蓝的前方。对于这些对手小蓝可以选择挑战,也可以选择避战。

身为高傲的骑士,小蓝从不走回头路,且只愿意挑战战力值越来越高的对手。

请你算算小蓝最多会挑战多少名对手?

输入描述:

输入第一行包括一个整数N,表示对手的个数;

第二行包括N个整数:a1,a2,...an,表示每个骑士的战力值;

1 <= N <= 3*10^5,1 <= ai <= 10^9。

输出描述:

输出一行整数表示答案。

参考答案:

import bisect
n = int(input())
a = list(map(int,input().split()))
q = [a[0]]
for i in range(1,n):ind = bisect.bisect_left(q,a[i])if ind == len(q):q.append(a[i])else:q[ind] = a[i]
print(len(q))

运行结果:

 

以下是我对此题的理解:

首先,从输入中获取对手的个数和每个对手的战力值;

创建一个空列表q,用于存储已经被挑战过的对手的战力值;

从第一个对手开始,遍历到最后一个对手,依次进行以下操作:

使用二分查找在列表q中找到小于等于当前对手战力值的最大值的索引;

如果找到的索引等于q的长度,说明当前对手的战力值大于当前已经挑战过的所有对手的战力值,将当前对手的战力值加入q中,否则,说明当前对手的战力值可以替换q中某个已经挑战过的对手的战力值,最后输出q的长度就可以了。


例题2:最长公共子序列

问题描述:

给定一个长度为N的数组a和一个长度为M的数组b,请你求出它们的最长公共子序列。

输入描述:

输入第一行包括两个整数N和M,分别表示数组a的长度和数组b的长度。

第二行输入包含N个整数a1,a2,...,an;

第三行包含M个整数b1,b2,...bm;

1 <= N,M <= 10^3,1 <= ai,bi <= 10^9

输出描述:

输出一行整数表示答案

参考答案:

a,b = map(int,input().split())
A = [0] + list(map(int,input().split()))
B = [0] + list(map(int,input().split()))
f = [[0]*(b + 1)for i in range(a + 1)]
for i in range(1,a + 1):for j in range(1,b + 1):if A[i] == B[j]:f[i][j] = f[i-1][j-1] + 1else:f[i][j] = max(f[i-1][j],f[i][j-1])print(f[a][b])

运行结果:

 

这道题用的是动态规划,比较简单,我就不做过多解释了。


例题3:倒水

问题描述:

小秋家里来了n位客人,编号为1,2,...,n,现在小秋要给每个客人倒水。

每个客人都有一个满意度,对于第i个客人,满意度是这样定义的:

如果小秋给第i个客人倒了ai毫升水,客人的满意度为bi;如果小秋给第i个客人倒了ci(ci > ai)毫升水,客人的满意度为di;

如果小秋给第i为客人倒的水不足ai毫升(也可以为0),客人的满意度为ei。

现在小秋有m毫升水,请问他要怎么倒水,才能让所有客人的满意度之和最大呢?你只需要求出所有客人的满意度之和的最大值。

输入描述:

第一行输入两个正整数n和m,表示客人的数量和小秋所拥有的水的体积;

接下来n行,每行5个整数ai,bi,ci,di,ei,第i行表示给第i位客人倒了ai毫升水的满意度为bi,给第i位客人倒了ci毫升水的满意度为di,倒水不足ai毫升水的满意度为ei。

输出格式:

输出仅一行,包含一个整数,表示所有课满意度之和的最大值。

参考答案:

import os
import sys
n,m = map(int,input().split())
f = [[0]*(m + 1) for i in range(n + 1)]
for i in range(1,n + 1):a,b,c,d,e = map(int,input().split())for j in range(m + 1):f[i][j] = f[i - 1][j] + eif j >= a:f[i][j]  = max(f[i][j],f[i - 1][j - a] + b)if j >= c:f[i][j] = max(f[i][j],f[i - 1][j - c] + d)
print(f[n][m])

运行结果:

 

以下是我对此题的理解:

我就不写成文字了,我把注释过的代码粘贴过来:

import os
import sys# 输入客人数量n和水的体积m
n, m = map(int, input().split())# 初始化动态规划数组f,f[i][j]表示考虑前i个客人,倒水体积为j时的最大满意度之和
f = [[0] * (m + 1) for i in range(n + 1)]# 遍历每位客人
for i in range(1, n + 1):# 获取当前客人的倒水参数a, b, c, d, e = map(int, input().split())# 遍历可能的倒水体积for j in range(m + 1):# 初始化当前状态为上一个状态加上当前客人倒水不足ai毫升时的满意度eif[i][j] = f[i - 1][j] + e# 如果当前剩余水量j大于等于ai,即可以倒ai毫升水给当前客人if j >= a:# 尝试用当前水量j减去ai毫升水,然后加上当前客人倒水ai毫升时的满意度bi,与之前状态f[i-1][j-ai]相比较,取最大值f[i][j] = max(f[i][j], f[i - 1][j - a] + b)# 如果当前剩余水量j大于等于ci,即可以倒ci毫升水给当前客人if j >= c:# 尝试用当前水量j减去ci毫升水,然后加上当前客人倒水ci毫升时的满意度di,与之前状态f[i-1][j-ci]相比较,取最大值f[i][j] = max(f[i][j], f[i - 1][j - c] + d)# 输出考虑了所有客人和水量为m时的最大满意度之和
print(f[n][m])

 例题4:盗墓分赃2

问题描述:

在一个探险者的团队中,小明和小红是合伙的盗墓贼。

他们成功盗取了一座古墓中的宝藏,其中包括n件不同重量的宝贵文物和黄金,第i件宝藏的重量为ai。

现在,他们希望公平地分配这些宝藏,使得小明所分得的宝藏的总重量等于小红所分得的宝藏的总重量。

请检查是否存在这样的分配方案,需要注意的是,不能对宝藏进行切割来平分重量,只能整个宝藏进行分配。

输入格式:

第一行包含一个正整数n,表示有n件宝藏;

接下来n行,第i行表示第i件宝藏的重量ai。

输出格式:

如果能公平分配就输出yes,否则输出no。

参考答案:

def work():n = int(input())aa = [0] + [int(input())for i in range(n)]tot = sum(aa)if tot % 2 != 0:print('no')returntot //= 2f = [[False]*(tot + 1) for i in range(n + 1)]f[0][0] = Truefor i in range(1,n + 1):for j in range(tot + 1):f[i][j] = f[i - 1][j]if j >= aa[i]:f[i][j] = f[i - 1][j - aa[i]]print('yes')if f[n][tot] else print('no')
if __name__ == '__main__':work()

运行结果:

 

 第一种做法有一个样例显示超时了,所以我优化了一下。

第二种做法:

def work():n = int(input())aa = [0] + [int(input())for i in range(n)]tot = sum(aa)if tot % 2 != 0:print('no')returntot //= 2f = [False]*(tot + 1)f[0] = Truefor i in range(1,n + 1):for j in range(tot,aa[i] - 1,-1):f[j] = f[j - aa[i]]print('yes')if f[tot] else print('no')
if __name__ == '__main__':work()

以下是我对此题的理解:

我用代码注释来表达我的思想:

def work():# 输入宝藏的数量nn = int(input())# 获取每件宝藏的重量并存储在列表aa中aa = [0] + [int(input()) for i in range(n)]# 计算所有宝藏的总重量tot = sum(aa)# 如果总重量为奇数,则无法公平分配,输出'no'并返回if tot % 2 != 0:print('no')return# 将总重量除以2,得到每个人应分得的宝藏的总重量tot //= 2# 创建一个布尔型数组f,f[i]表示是否存在一种方案使得宝藏的总重量为if = [False] * (tot + 1)# 初始化f[0]为True,表示当没有宝藏时,总重量为0f[0] = True# 遍历每件宝藏for i in range(1, n + 1):# 从总重量到当前宝藏重量之间的位置开始遍历for j in range(tot, aa[i] - 1, -1):# 如果存在一种分配方案使得总重量为j的话,那么也一定存在一种分配方案使得总重量为j + 宝藏重量f[j] = f[j - aa[i]]# 判断是否存在一种分配方案使得总重量为tot,如果存在,则输出'yes',否则输出'no'print('yes') if f[tot] else print('no')if __name__ == '__main__':work()

OK,今天状态不错,这几个题还好,下一篇继续! 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/539854.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

目前研一,是选 FPGA 还是 Linux 嵌入式?

目前研一&#xff0c;是选 FPGA 还是 Linux 嵌入式? 在开始前我有一些资料&#xff0c;是我根据网友给的问题精心整理了一份「Linux 的资料从专业入门到高级教程」&#xff0c; 点个关注在评论区回复“888”之后私信回复“888”&#xff0c;全部无偿共享给大家&#xff01;&a…

mac安全干净卸载Anaconda3

使用which python显示当前使用的是/Users/username/anaconda3/bin/python 现在想卸载Anaconda&#xff0c;恢复使用mac系统自带的Python 删除隐藏文件目录 rm -rf ~/.anaconda修改~/.bash_profile文件&#xff0c;将anaconda相关删除 也有可能不是~/.bash_profile而是~/.zs…

Infineon_TC264智能车代码初探及C语言深度学习(二)

本篇文章记录我在智能车竞赛中&#xff0c;对 Infineon_TC264 这款芯片的底层库函数的学习分析。通过深入地对其库函数进行分析&#xff0c;C语言深入的知识得以再次在编程中呈现和运用。故觉得很有必要在此进行记录分享一下。 目录 ​编辑 一、代码段分析 NO.1 指向结构体…

大米自动化生产线的运作原理与科技创新

在当今科技飞速发展的时代&#xff0c;自动化生产线已经成为各个行业提高效率、降低成本的重要工具。而在粮食产业中&#xff0c;大米的自动化生产线更是以其独特的魅力&#xff0c;引领着粮食加工业的转型升级。星派将带您深入了解大米自动化生产线的运作原理&#xff0c;以及…

某狗网翻译接口逆向之webpack扣取

​​​​​逆向网址 aHR0cHM6Ly9mYW55aS5zb2dvdS5jb20 逆向链接 aHR0cHM6Ly9mYW55aS5zb2dvdS5jb20vdGV4dA 逆向接口 aHR0cHM6Ly9mYW55aS5zb2dvdS5jb20vYXBpL3RyYW5zcGMvdGV4dC9yZXN1bHQ 逆向过程 请求方式&#xff1a;POST 参数构成&#xff1a; 【s】 1b921dbefaa8d939afca…

2024-3-13,14(CSS)

1.复合选择器 有两个或者多个基础选择器&#xff0c;通过不同的方式组合而成。 目的是更加准确高效的选择目标元素&#xff08;标签&#xff09; 分类&#xff1a; 后代选择器&#xff1a;选中某个元素的所有后代元素 写法&#xff1a;父选择器 子选择器 {CSS属性}&#x…

Java代码审计安全篇-XXE(XML外部实体注入)漏洞

前言&#xff1a; 堕落了三个月&#xff0c;现在因为被找实习而困扰&#xff0c;着实自己能力不足&#xff0c;从今天开始 每天沉淀一点点 &#xff0c;准备秋招 加油 注意&#xff1a; 本文章参考qax的网络安全java代码审计&#xff0c;记录自己的学习过程&#xff0c;还希望各…

Spring Bean的生命周期流程

前言 Java 中的公共类称之为Java Bean&#xff0c;而 Spring 中的 Bean 指的是将对象的生命周期&#xff0c;交给Spring IoC 容器来管理的对象。所以 Spring 中的 Bean 对象在使用时&#xff0c;无需通过 new 来创建对象&#xff0c;只需要通过 DI&#xff08;依赖注入&#x…

【Java设计模式】二十一、访问者模式

文章目录 1、访问者模式2、案例&#xff1a;宠物喂食3、总结 1、访问者模式 封装一些作用于某种容器中各个元素的操作。相关角色&#xff1a; 抽象访问者&#xff1a;定义了对每一类元素访问的行为。方法个数等于具体元素类的个数&#xff0c;方法形参是可访问的元素。具体访…

固态硬盘有缓存和没缓存有什么区别

固态硬盘&#xff08;SSD&#xff09;已经成为现代计算机的重要组成部分&#xff0c;它们提供了比传统机械硬盘更快的读写速度&#xff0c;从而显著提升了操作系统的运行速度和应用程序的加载效率。 其中&#xff0c;缓存&#xff08;Cache&#xff09;是固态硬盘中一个重要的…

留学生课设|R语言|研究方法课设

目录 INSTRUCTIONS Question 1. Understanding Quantitative Research Question 2. Inputting data into Jamovi and creating variables (using the dataset) Question 3. Outliers Question 4. Tests for mean difference Question 5. Correlation Analysis INSTRUCTIO…

idea如何使用,从激活开始

idea到期后激活使用 如何使用 点击阅读 idea分享