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

news2025/2/24 14:09:29

今日复习内容:算法双周赛

第一题:疯狂星期六

题目描述:

麦肯鸡是一家名声在外的汉堡店,他们最近推出了一份名为vivo50的套餐,只需要在门口大声喊出vivo50,就可以获得这个套餐。

现在,请你打印出vivo50,告诉计算机你想要这个套餐,虽然计算机无法为你提供这个套餐,但它可以帮助你通过本题。

输入格式:

本题为填空题,无需输入即可作答。

输出格式:

输出一个字符串,表示答案。

参考答案:

print("vivo50")

这个结果我就不给了,大家都知道。 

第二题:忙碌的售票员

题目描述:

小蓝是一家旅行社的售票员,他每天都很忙碌。

为什么呢?原因是这样的,当地文旅局与旅行社合作,所以旅行社能够以更低廉的价格拿到票,然后旅行社再将这些票配套导游服务一起卖给顾客。虽然看起来十分划算,但是这可苦了我们的售票员小蓝。因为即使能够得到更低价的票,但是票仍然需要从机器中打印出,文旅局的机器十分老旧,但是旅行社的订单又十分的多,这就导致了小蓝需要耗费大量的时间来打印票据。

文旅局共有3台打票机,每台机器每次只能打印1张票,打印一张票的时间是x分钟(即需要操作机器x分钟),但是机器每打印完一张票后,都需要停机y分钟,不然的话,机器会过热宕机,俗称“冷却”。

小蓝共有a张票需要打,同一时刻只能操作一台机器。他想知道,他最少需要多长时间才能打完所有的票。

输入格式:

第一行输入一个整数T(1 <= T <= 10^4),代表测试数据组数。

接下来T行,每行3个整数x,y,a(1 <= x,y,a <= 10^7),代表打票时间x,冷却时间y,共有a张票需要打。

输出格式:

输出T行,每行一个整数,代表最少需要多长时间可以打印完所有的票,单位为分钟。

参考答案:

t = int(input())

def sol():
    for i in range(t):
        x, y, a = map(int, input().split())
        ans = 0
        if 2 * x > y:
            ans = x * a
        else:
            sv = (a - 1) // 3
            rv = a - sv * 3
            ans = rv * x + sv * (x + y)
        print(ans)

sol()

运行结果: 

写一个解析:

这个代码主要是要想清楚这3台机器是怎么运行的。如果单次打印票据的时间为x,一开始,我们使用第一台机器进行打印,然后它休息需要y分钟,接着我们用第二台,使用完第二台后,机器一共运行了2x分钟,此时就要用第三台了,我们来考虑第一台,如果在这段时间内,两台机器运行的时间大于它休息的时间,那就可以继续无缝衔接地继续使用第一台,所以此时的条件是2x < y,那么这种情况下,打印全部票的最短时间就是x * a。然后我们当然是考虑2x  > y的情况了,此时前两台机器都已经用过了,但是第一台机器还不能使用,所以只能把整个过程看作一个循环,3台机器运行完为一个循环,所以特殊情况特殊对待,我们可以将打印票据的过程分为两个部分计算,一个部分是打印剩余票据所需要的时间,记为rv * x,另一个部分是机器冷却所需要的时间,记为sv * (x + y),其中rv表示剩余的未打印的票据数,sv表示需要进行冷却的次数。

基于每打印3张票就需要冷却一次的原则,具体来说,如果需要打印的票数是3的倍数,那么每打印三张就需要进行一次冷却,因此需要进行冷却的次数就是a // 3,如果需要打印的票数不是3的倍数,那么最后剩下的票数就不足3张,这些票就可以在最后一次冷却之前连续打印完,因此需要进行冷却的次数 就是(a - 1) // 3。ok,难理解的就是这几个点,剩下的我就不解释了。


第三题:兽之泪Ⅱ

题目描述:

在蓝桥王国,流传着一个古老的传说:在怪兽谷,由一笔由神圣骑士留下的宝藏。

小蓝是一位年轻而勇敢的冒险家,他决定去寻找宝藏,根据远古卷轴的提示,如果要找到宝藏,那么需要集齐n滴兽之泪,同时卷轴中也记载了,每击败一次怪兽,就能够收集一滴兽之泪。

小蓝知道,这些怪物并非泛泛之辈,每一只都拥有强大的力量和狡猾的技巧,每一只怪兽都要独特的弱点和对策,小蓝必须谨慎选择战斗的策略和使用的能量。

在怪兽谷中,有k只怪兽,对于第i只怪兽,第一次击败它需要xi点能量,再一次击败它需要yi点能量。在挑战过程中,前k - 1只怪兽可以随意挑战,但是第k只怪兽是怪兽之王,如果要挑战第k只怪兽,那么对于前k - 1只怪兽至少都要击败一次。

小蓝想知道,如果要集齐n滴兽之泪,那么至少需要多少能量。

输入格式:

第一行包含一个整数T(T <= 10^5),代表测试组数。

每组数据包含如下部分:

第一行包含两个整数k和n,表示怪物的数量和需要收集的兽之泪的数量。2 <= k <= 10^5,1 <= n <=  2 * 10^5。

接下来k行,每行包含两个整数xi和yi,表示第i只怪物第一次和后续击败所需要的能力(1 <= xi,yi <= 10^9)。

输出格式:

对于每组数据,输出一个整数,表示小蓝至少需要多少点能量才能收集完成。

参考答案:

import os
import sys
import heapq
from math import inf
import bisect

# 读取输入
t = int(input())
for _ in range(t):
    k, n = list(map(int, input().split()))
    q = []
    res1 = 0  # 打兽之王
    res2_2 = inf  # 不打兽之王
    number1 = []
    number2 = []
    
    for i in range(k):
        x, y = list(map(int, input().split()))
        res1 += x
        number2.append(y)
        if i == k - 1:
            continue
        heapq.heappush(q, (x, 1, i))
        number1.append(x)
    
    # 统计不打兽之王的结果
    # 排序
    new_number1 = sorted([[v, i] for i, v in enumerate(number1)])
    # 前缀和
    prefixsum = [0]
    s = 0
    for x, index in new_number1:
        s += x
        prefixsum.append(s)
    
    # 枚举 y + 二分
    for y, i in sorted([[y, i] for i, y in enumerate(number2[:-1])]):
        index = bisect.bisect_left(new_number1, [y, -1])
        # index 表示 y 前面的 x 的个数
        if index >= n:  # 说明,只选 x 就能把泪填满了
            res2_2 = min(res2_2, prefixsum[n])
        else:
            if y < number1[i]:  # 没有选到 y 的第一次
                res2_2 = min(res2_2, prefixsum[index] + number1[i] + y * (n - 1 - index))
            else:
                res2_2 = min(res2_2, prefixsum[index] + y * (n - index))
    
    if n < k:  # 一定是不打兽之王
        print(res2_2)
    else:
        print(min(res2_2, res1 + (n - k) * min(number2)))

运行结果:

这个题我灵感不错,但我没想到我的代码那么长,我来记录一下我的解题过程。 

我用手写版本的。


好了,这篇就写到这里,算法双周赛的题太多了,我就先写这些,下一篇继续

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B

2024年4月18日&#xff0c;meta开源了Llama 3大模型[1]&#xff0c;虽然只有8B[2]和70B[3]两个版本&#xff0c;但Llama 3表现出来的强大能力还是让AI大模型界为之震撼了一番&#xff0c;本人亲测Llama3-70B版本的推理能力十分接近于OpenAI的GPT-4[4]&#xff0c;何况还有一个4…

ubuntu搭建jupyter_notebook服务器

环境&#xff1a;ubuntu 22.04 目录 环境&#xff1a;ubuntu 22.04 一、创建一个anaconda用户 创建用户condaUser 为用户condaUser设置密码 开放opt文件夹的权限 登录condaUser用户 二、安装anaconda 下载anaconda 安装anaconda 三、添加环境变量 四、anaconda换源 …

Linux 麒麟系统安装

国产麒麟系统官网地址&#xff1a; https://www.openkylin.top/downloads/ 下载该镜像后&#xff0c;使用VMware部署一个虚拟机&#xff1a; 完成虚拟机创建。点击&#xff1a;“开启此虚拟机” 选择“试用试用开放麒麟而不安装&#xff08;T&#xff09;”&#xff0c;进入op…

Python 全栈体系【四阶】(三十七)

第五章 深度学习 八、目标检测 3. 目标检测模型 3.1 R-CNN 系列 3.1.1 R-CNN 3.1.1.1 定义 R-CNN(全称 Regions with CNN features) &#xff0c;是 R-CNN 系列的第一代算法&#xff0c;其实没有过多的使用“深度学习”思想&#xff0c;而是将“深度学习”和传统的“计算…

springboot mongodb分片集群事务

前置 mongodb分片集群想要使用事务,需要对应分片没有仲裁节点 代码 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-mongodb</artifactId><version>2.1.0.RELEASE</version></d…

java版本共存与fastjson反序列化rmi服务器的搭建

文章目录 java 8下载远程加载类工具编译工具mvn多版本共存配置mvn编译marshalsec编译rce文件利用marshalsec加载远程RCE类 java 8下载 链接&#xff1a;https://pan.baidu.com/s/1B8U9v8QAe4Vc67Q84_nqcg?pwd0000 提取码&#xff1a;0000 远程加载类工具 https://github.co…

Ubuntu+Systemd服务+实现开机自启/关机启动脚本

开机自启 1.创建一个新的 systemd 服务文件 现在随便一个地方创建txt文档 如果想要启动sh脚本&#xff0c;就把下面的代码输入到txt文档中 [Unit] DescriptionRun Python script on specific executable run Afternetwork.target[Service] Typesimple ExecStart/home/tech/…

misc学习

一.知识点 1.BMP文件 BMP文件主要有四部分组成&#xff0c;位图头、位图信息、调色板、位图数据。 bmp文件头(bmp file header)&#xff1a;提供文件的格式、大小等信息 位图信息头(bitmap information)&#xff1a;提供图像数据的尺寸、位平面数、压缩方式、颜色索引等信息…

Linux操作系统·进程管理

一、什么是进程 1.作业和进程的概念 Linux是一个多用户多任务的操作系统。多用户是指多个用户可以在同一时间使用计算机系统&#xff1b;多任务是指Linux可以同时执行几个任务&#xff0c;它可以在还未执行完一个任务时又执行另一项任务。为了完成这些任务&#xff0c;系统上…

AI写作神器种草:好用的AI写作工具推荐!AI写作生成器~

随着人工智能技术的不断发展&#xff0c;AI工具已经成为我们日常生活和工作中不可或缺的一部分。从智能助手到自动翻译&#xff0c;从数据分析到图像识别&#xff0c;AI技术的应用已经渗透到各个领域。在这篇文章中&#xff0c;我将分享一些我个人认为最好用的AI工具&#xff0…

思考!思考!jmeter线程数≠用户并发数

最近又在搞性能测试了&#xff0c;相较于之前的写脚本出数据就完事&#xff0c;这次深入的思考了一下测试出来的指标&#xff0c;到底有什么意义&#xff1f;&#xff1f;&#xff1f; 绞尽脑汁思考了好几天&#xff0c;终于有了点思路&#xff0c;写出来与大家分享&#xff0…

【论文阅读】ChipNeMo中的数据集处理

前面总体学习了《ChipNeMo: Domain-Adapted LLMs for Chip Design》&#xff0c;然后又继续仔细看了论文中的领域适配分词和领域数据微调的预训练检索模型&#xff0c;对于数据集的处理&#xff0c;也需要仔细看一下。 提炼重点&#xff1a;1&#xff09;对于数据集&#xff0…

节假日如何快速回应客户消息?

在宝贵的休闲时光或者特殊的节日期间&#xff0c;有时候由于工作、家庭等原因&#xff0c;我们很难及时回应客户的消息。那么如何在忙碌之时&#xff0c;如何确保与他人的交流畅通无阻呢&#xff1f;答案就是使用微信私域流量管理系统。 01 机器人自动回复设置 机器人自动回…

我五一是这样计划的,第一天...

前言 这个时间点&#xff0c;大多数人一定已经“峡谷做好准备全军出击”或者在出行的路上了。这个时间我也在回老家路上聊一聊。 行程 老读者都知道我老家在内蒙的西北的边陲城市&#xff0c;往年票都是随便买、除了春运几乎坐不满&#xff0c;今年五一居然也需要抢票&#…

JavaScript基础(二)

JavaScript基础&#xff08;一&#xff09; 相信看完上一篇文章的你对变量的类型和使用已经了解了&#xff0c;接下来我们将对变量间的转化以及Js中的三大结构展开叙述。 类型转换 首先&#xff0c;我们要了解为什么我们需要转换类型呢&#xff1f; 在表单提交中&#xff0c;…

CCF-CSP真题题解:201409-3 字符串匹配

201409-3 字符串匹配 #include <iostream> #include <cstring> #include <algorithm> using namespace std;int n, type; string s, p;string tolower(string s) {string res;for (char c : s) res tolower(c);return res; }int main() {cin >> p >…

给rwkv_pytorch增加rag

RAG 参考地址语义模型地址选择该模型使用方法方法二安装方法下载模型到本地材料材料处理语义分割计算得分根据得分 分割文本 构建向量数据库问答匹配问答整合 参考地址 RAG简单教程 分割策略 语义模型地址 hf 选择该模型 gte 使用方法 import torch.nn.functional as F…

开源博客项目Blog .NET Core源码学习(18:App.Hosting项目结构分析-6)

本文学习并分析App.Hosting项目中后台管理页面的_AminLayout.cshtml模版页面和登录页面。 _AminLayout.cshtml模版页面 后台管理页面中的大部分页面都使用_AminLayout.cshtml作为模板页面&#xff0c;如下图所示&#xff0c;后台页面的视图内容放置在表单中&#xff0c;使用la…

再回顾const int* p, int const* p,int* const p 的区别

目录 一、const int* p 和 int const* p &#xff08;常量指针&#xff09; 1.1 p 指向的内存不能通过指针p 修改1.2 其他指针可以修改p 指向的内存1.3 指针p 可以重新指向其他地址 二、int* const p &#xff08;指针常量&#xff09; 2.1 p 定义的时候初始化2.2 p 定义的时候…

Adobe推出AI视频超分辨率工具VideoGigaGAN

&#x1f989; AI新闻 &#x1f680; Adobe推出AI视频超分辨率工具VideoGigaGAN 摘要&#xff1a;Adobe公司最新推出的AI工具VideoGigaGAN&#xff0c;利用上采样技术将视频分辨率从128128提升至10241024。这一工具基于GigaGAN模型开发&#xff0c;专注于生成视频超分辨率&am…