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

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

第一题:疯狂星期六

题目描述:

麦肯鸡是一家名声在外的汉堡店,他们最近推出了一份名为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 = 0if 2 * x > y:ans = x * aelse:sv = (a - 1) // 3rv = a - sv * 3ans = 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 += xnumber2.append(y)if i == k - 1:continueheapq.heappush(q, (x, 1, i))number1.append(x)# 统计不打兽之王的结果# 排序new_number1 = sorted([[v, i] for i, v in enumerate(number1)])# 前缀和prefixsum = [0]s = 0for x, index in new_number1:s += xprefixsum.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.mzph.cn/bicheng/4042.shtml

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

相关文章

【VUE】解决 Element UI 中 el-tab 切换时 ECharts 渲染宽度问题

解决 Element UI 中 el-tab 切换时 ECharts 渲染宽度问题 在使用 Element UI 的 el-tabs 组件时&#xff0c;我们常常会遇到一个问题&#xff1a;当 ECharts 图表被放在非当前激活的 Tab 内时&#xff0c;图表无法正确渲染其宽度和高度。由于在 Tab 未激活状态下&#xff0c;图…

[Java、Android面试]_21_Dalvik VM与JVM的区别

欢迎查看合集&#xff1a; Java、Android面试高频系列文章合集 文章目录 1. 结构2. 编译3. 运行环境4. Dalvik进程管理 Dalvik是android系统中的虚拟机&#xff0c;JVM是java虚拟机。 Dalvik VM可以支持将已转化为.dex文件格式的java应用程序的运行&#xff0c;.dex是专为Dalvi…

Windows程序设计 - 字符与字符串处理

目录 字符编码的问题 ANSI Vs Unicode 函数版本区分 C RunTime库 老生常谈的ASCII和UNICODE支持性 安全字符串函数 推介的字符和字符串处理的方式 ASCII与UNICODE互转 Reference 字符编码的问题 对于一些像我这样的初学者&#xff1a;很喜欢认为字符串的处理就是将字…

了解ASK模块STX883Pro和超外接收模块SRX883Pro的独特之处 STX883Pro模块具有以下特点:

高发射功率&#xff1a;STX883Pro具有较高的发射功率&#xff0c;可实现长距离的信号传输&#xff0c;适用于需要覆盖广泛区域的应用场景。 高频率稳定性&#xff1a;具备稳定的频率输出&#xff0c;确保信号传输的可靠性和一致性&#xff0c;避免频率漂移导致的通信故障。 大…

Ubuntu 18.04 安装 CMake Ceres-Solver 记录

1. 安装 CMake-3.22.1 不可卸载原有版本 CMake&#xff08;防止 ROS 出现问题&#xff09;&#xff0c;只需建立软链接即可 1. 源码下载并解压wget https://cmake.org/files/v3.22/cmake-3.22.1.tar.gz tar -xvzf cmake-3.22.1.tar.gz2. 移动到合适目录sudo mv cmake-3.22.1 /u…

C++ | Leetcode C++题解之第48题旋转图像

题目&#xff1a; 题解&#xff1a; class Solution { public:void rotate(vector<vector<int>>& matrix) {int n matrix.size();// 水平翻转for (int i 0; i < n / 2; i) {for (int j 0; j < n; j) {swap(matrix[i][j], matrix[n - i - 1][j]);}}//…

Thread方法具体解析

对于run方法 如果该线程是使用单独的 Runnable run 对象构造的&#xff0c;则调用该 Runnable 对象的 run 方法&#xff1b;否则&#xff0c;此方法不执行任何操作并返回。 对于start方法 导致该线程开始执行&#xff1b; Java虚拟机调用该线程的run方法。 这里介绍一个快捷键…

Java Spring 中构造函数注入和Setter注入的优缺点

在使用Java Spring框架进行依赖注入时&#xff0c;我们常常会遇到构造函数注入和Setter注入两种方式。这两种方式各有优缺点&#xff0c;本文将对它们进行比较和分析&#xff0c;帮助开发者在实际项目中做出合适的选择。 构造函数注入 构造函数注入是通过在类的构造函数中传入…

Windows Vscode ModuleNotFoundError: No module named

故障现象&#xff1a; Windows Vscode 经常会遇到模块路径查找失败的异常。 如运行2_from_import_test.py后&#xff0c;报错&#xff1a; 发生异常: ModuleNotFoundError No module named programmer File "D:\leolab\programmer\2_from_import_test.py", line 8…

什么是数字化运营?

目录 一、什么是数字化运营&#xff1f; 二、数字化运营的重要性是什么&#xff1f; 三、数字化运营的具体步骤和措施是什么&#xff1f; 四、数据化决策是什么&#xff1f; 一、什么是数字化运营&#xff1f; 数字化运营是利用数字技术和数据分析来优化企业的业务流程和运…

C语言 | Leetcode C语言题解之第51题N皇后

题目&#xff1a; 题解&#xff1a; int solutionsSize;char** generateBoard(int* queens, int n) {char** board (char**)malloc(sizeof(char*) * n);for (int i 0; i < n; i) {board[i] (char*)malloc(sizeof(char) * (n 1));for (int j 0; j < n; j) board[i][…

LeetCode-104-二叉树最大深度

题目&#xff1a; 给定一个二叉树 root &#xff0c;返回其最大深度。 二叉树的 最大深度 是指从根节点到最远叶子节点的最长路径上的节点数。 思路&#xff1a;不断往下遍历&#xff0c;每往深层遍历一层&#xff0c;深度加一&#xff0c;当遍历到null&#xff0c;与当前最大…

Linux内核驱动开发-006内核定时器

1驱动程序 /*************************************************************************> File Name: timer.c> Author: yas> Mail: rage_yashotmail.com> Created Time: 2024年04月23日 星期二 19时20分42秒*************************************************…

每日JAVA高级面试题

Java 高级面试问题及答案 以下是一些在Java高级面试中可能会遇到的问题&#xff0c;以及对这些问题的探讨和回答。 问题 1: Java内存模型是什么&#xff1f;请解释其重要性。 探讨&#xff1a; Java内存模型&#xff08;Java Memory Model, JMM&#xff09;是Java虚拟机&…

【unity】三维数学应用(计算线和面的交点)

【unity】三维数学应用&#xff08;计算线和面的交点&#xff09; 实现方法有多种&#xff0c;下面介绍一种简单的方法。利用一个点指向面上任意点的向量&#xff0c;到该面法线的投影长度相同的基本原理&#xff0c;结合相似三角形既可以求出交点。 原理 如下图 GD组成的线段…

c++图论基础(1)

目录 无向图 无向图度 无向图性质 有向图 有向图度 有向图性质 图的分类&#xff1a; 稀疏图&#xff1a; 稠密图&#xff1a; 零图&#xff1a; 有向完全图&#xff1a; 无向完全图&#xff1a; 度序列&#xff1a; 图是由顶点集合(简称点集)和顶点间的边(简称边…

华为机试:夺宝奇兵

夺宝奇兵 | 时间限制&#xff1a;1秒 | 内存限制&#xff1a;262144K 一个3人寻宝团队搜寻沉船成功&#xff0c;获得一笔宝藏&#xff0c;领头人为不起纷争&#xff0c;决定将财宝分成3N份&#xff0c;每次3人从分好的3堆宝藏中依次拿取&#xff0c;领头人第一拿&#xff0c;你…

Weblogic JMS

简介 全称:WebLogic Server的Java Messaging Service(JMS) WebLogic JMS 是与 WebLogic Server 平台紧密集成的企业级消息传递系统。 Java Message Service (JMS) API 是一种消息传递标准,允许基于 Java Platform Enterprise Edition (Java EE) 的应用程序组件创建、发送、…

DiffSpeaker 部署踩坑笔记

目录 依赖项&#xff1a; Windows环境下安装psbody 下载安装boost 编译安装psbody 保存mp4报错解决 语音驱动的3D面部动画&#xff0c;可以用扩散模型或Transformer架构实现。然而它们的简单组合并没有性能的提升。作者怀疑这是由于缺乏配对的音频-4D数据&#xff0c;这对…

windows rabbitMq安装

一、Erlang 环境准备 下载安装包 跟我们跑java项目&#xff0c;要装jdk类似。rabbitMQ是基于Erlang开发的&#xff0c;因此安装rabbitMQ服务器之前&#xff0c;需要先安装Erlang环境。 官网直接下载windows直装版本&#xff1a;https://www.erlang.org/downloads 无脑安装&a…