【2024-03-18】顺丰春招笔试两道编程题解

恭喜发现宝藏!搜索公众号【TechGuide】回复公司名,解锁更多新鲜好文和互联网大厂的笔经面经。
作者@TechGuide【全网同名】

订阅专栏: 【专享版】2024最新大厂笔试真题解析,错过必后悔的宝藏资源!

第一题:转圈游戏

题目描述

小盖在玩一个叫转转转的游戏。游戏规则为依次点击三个绕着圈旋转的按钮。若在按钮转到指定位置时进行点击则视为成功并继续点击下一个圈,否则视为失败并回到第一个圈继续。每个圈无论成功或失败均耗时1秒。

小盖在第一个圈失败了a次,在第二个圈失败了b次,在第三个圈失败了c次,最后成功了一次成功通关。

已知小盖今天总共耗时为t和a,b,c其中一个的值,求今天小盖“最多”失败了多少次和“最少”失败了多少次。

输入描述

输入一行,形如x v t,中间用空格隔开。

其中x代表字母a/b/c中的一个,代表知道的是哪一个值。

v(1≤v≤10^6)是上述x具体的值,表示在a/b/c其中一个环节失败的次数。

t(1≤t≤6×10^6)是总耗时。

输出描述

在一行中输出用空格分隔的两个数,分别代表小盖最多/最少失败了多少次。

样例

输入

a 3 12

输出

6 5

样例说明

对于样例,有以下两种可能:
在第一个圈失败了三次,第二个圈失败了三次,第三个圈失败了零次,最后成功了一次,
总耗时为1+1+1+2+2+2+3=12,共失败六次。
在第一个圈失败了三次,第二个圈失败了零次,第三个圈失败了两次,最后成功了一次,
总耗时为1+1+1+3+3+3=12,共失败五次。

思路

分情况模拟。首先t需要扣除每个环节必须使用的1s,共3s,之后根据x的情况分类讨论,如果已知第一个圈失败了a次,那么在第二个圈中,最多失败次数等于(总耗时 - 第一个圈失败次数)/ 2,最少失败次数等于(总耗时 - 第一个圈失败次数)/ 3 + 第一个圈失败次数。
对于已知第二个和第三个圈失败次数这两种情况,也是类似分析,比较绕,不再赘述,可以结合代码分析。

代码

Python版本

import sysfor line in sys.stdin:x, v, t = line.split()v, t = int(v), int(t)minn, maxx = 0, 0t -= 3if x == 'a':t -= vtime1 = t // 2maxx = time1 + vtime2 = t // 3 if t % 3 == 0 else t // 3 + 1minn = time2 + velif x == 'b':t -= v * 2maxx = v + ttime2 = t // 3 if t % 3 == 0 else t // 3 + (t % 3)minn = time2 + velse:t -= v * 3maxx = v + tminn = v + t // 2 + (t % 2)print(maxx, minn)
# vx公众号关注TechGuide,专业生产offer收割机,代码可能需要少量调试。

CPP版本

#include <iostream>
#include <string>using namespace std;int main() {string line;while (getline(cin, line)) {char x;int v, t;sscanf(line.c_str(), "%c %d %d", &x, &v, &t);int minn = 0, maxx = 0;t -= 3;if (x == 'a') {t -= v;int time1 = t / 2;maxx = time1 + v;int time2 = 0;if (t % 3 == 0) {time2 = t / 3;} else {time2 = t / 3 + 1;}minn = time2 + v;} else if (x == 'b') {t -= v * 2; maxx = v + t;int time2 = 0;if (t % 3 == 0) {time2 = t / 3;} else {time2 = t / 3 + (t % 3);}minn = time2 + v;} else {t -= v * 3;maxx = v + t;minn = v + t / 2 + (t % 2);}cout << maxx << " " << minn << endl;}return 0;
}
// vx公众号关注TechGuide,专业生产offer收割机,代码可能需要少量调试。

第二题:钓鱼比赛

题目描述

小盖参加了一个钓鱼比赛,比赛时间一共T秒,看参赛者谁钓上来的鱼最多。

一共有n个池子,不同的池子里鱼的类型不同,同一个池子里鱼的类型相同。参赛者只有一条鱼竿,同一时刻只能在一个池子里钓一条鱼,一个池子的鱼最多可以钓一条。第i个池子里的鱼需要花t[i]的时间才可以钓上来,同时每个池子都有一个特定参数a[i],它的意思是这个池子里的鱼被钓上来后算有效得分需要满足一个条件,就是整场比赛该参赛人员钓上的鱼的总数不能超过a[i]。你能帮助小盖合理安排,使得钓上可以算有效得分的鱼最多么?

输入描述

第一行两个整数n和T,1<=n<=200000, 1<=T<=1000000000;

接下来n行,每行两个整数a[i],t[i], 1<=a[i]<=n, 1<=t[i]<=10000

输出描述

一行,一个整数,表示小盖可以钓上的算有效得分的鱼的最大数量。

样例

输入

5 300
3 100
4 150
4 80
2 90
2 300

输出

2

样例说明

比赛时长为300秒,小盖可以钓第1条和第2条,一共花费250秒,一共2条,不超过3或4
如果钓第1,3,4条,虽然时间来得及,但是由于第4条a是2,一共钓了3条,不满足条件,答案还是2。

思路

二分,注意将所有池子按照钓鱼时间从小到大排序,因为如果钓鱼时间越短,可以钓的鱼就越多。maxFish是用于确定小盖可以钓上算有效得分的鱼的最大数量,而定义check则是为了在二分过程中检查在给定的钓鱼时间内,小盖是否能够钓到至少x条鱼,并且满足每个池子的鱼的数量限制。明白了这两个子功能的含义,就明白了二分的意义,就是通过不断调整区间范围,在保证每个池子的鱼的数量限制的前提下,找到最大的x,同时满足小盖能够钓到至少x条鱼,并且满足每个池子的鱼的数量限制,使用到了贪心的思想。

代码

Java版本

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int T = scanner.nextInt();int[][] pools = new int[n][2];for (int i = 0; i < n; i++) {pools[i][0] = scanner.nextInt();pools[i][1] = scanner.nextInt();}Arrays.sort(pools, Comparator.comparingInt(o -> o[1]));System.out.println(maxFish(pools, T));}public static int maxFish(int[][] pools, int T) {int left = 0, right = T;while (left < right) {int mid = (left + right + 1) / 2;if (check(pools, mid, T)) {left = mid;} else {right = mid - 1;}}return right;}public static boolean check(int[][] pools, int x, int T) {int fishCount = 0;int curTime = T;for (int[] pool : pools) {int fishLimit = pool[0];int timeNeeded = pool[1];if (fishLimit < x) continue;if (timeNeeded > curTime) break;curTime -= timeNeeded;fishCount++;}return fishCount >= x;}
}
// vx公众号关注TechGuide,专业生产offer收割机,代码可能需要少量调试。

CPP版本

#include <iostream>
#include <vector>
#include <algorithm>using namespace std;bool check(vector<vector<int>>& pools, int x, int T) {int fishCount = 0;int curTime = T;for (auto& pool : pools) {int fishLimit = pool[0];int timeNeeded = pool[1];if (fishLimit < x) continue;if (timeNeeded > curTime) break;curTime -= timeNeeded;fishCount++;}return fishCount >= x;
}int maxFish(vector<vector<int>>& pools, int T) {int left = 0, right = T;while (left < right) {int mid = (left + right + 1) / 2;if (check(pools, mid, T)) {left = mid;} else {right = mid - 1;}}return right;
}int main() {int n, T;cin >> n >> T;vector<vector<int>> pools(n, vector<int>(2));for (int i = 0; i < n; i++) {cin >> pools[i][0] >> pools[i][1];}sort(pools.begin(), pools.end(), [](const vector<int>& a, const vector<int>& b) {return a[1] < b[1];});cout << maxFish(pools, T) << endl;return 0;
}
// vx公众号关注TechGuide,专业生产offer收割机,代码可能需要少量调试。

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

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

相关文章

超越想象的数据可视化:五大工具引领新潮流

在数据分析领域&#xff0c;数据可视化工具是每位分析师的得力助手。它们能够将复杂的数据转化为直观、易懂的图表和图像&#xff0c;帮助分析师快速洞察数据背后的规律与趋势。下面&#xff0c;我将从数据分析师的角度&#xff0c;为大家介绍五个常用的数据可视化工具。 一、…

【vue.js】文档解读【day 5】| ref模板引用

如果阅读有疑问的话&#xff0c;欢迎评论或私信&#xff01;&#xff01; 本人会很热心的阐述自己的想法&#xff01;谢谢&#xff01;&#xff01;&#xff01; 文章目录 模板引用前言访问模板引用模板引用与v-if、v-show的结合v-for中的模板引用函数模板引用 模板引用 前言 …

Vue.js+SpringBoot开发食品生产管理系统

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 加工厂管理模块2.2 客户管理模块2.3 食品管理模块2.4 生产销售订单管理模块2.5 系统管理模块2.6 其他管理模块 三、系统展示四、核心代码4.1 查询食品4.2 查询加工厂4.3 新增生产订单4.4 新增销售订单4.5 查询客户 五、…

二蛋赠书十八期:《一本书讲透Elasticsearch:原理、进阶与工程实践》

Elasticsearch 是一种强大的搜索和分析引擎&#xff0c;被广泛用于各种应用中&#xff0c;以其强大的全文搜索能力而著称。 不过&#xff0c;在日常管理 Elasticsearch 时&#xff0c;我们经常需要对索引进行保护&#xff0c;以防止数据被意外修改或删除&#xff0c;特别是在进…

PC-DARTS: PARTIAL CHANNEL CONNECTIONS FOR MEMORY-EFFICIENT ARCHITECTURE SEARCH

PC-DARTS&#xff1a;用于内存高效架构搜索的部分通道连接 论文链接&#xff1a;https://arxiv.org/abs/1907.05737 项目链接&#xff1a;https://github.com/yuhuixu1993/PC-DARTS ABSTRACT 可微分体系结构搜索(DARTS)在寻找有效的网络体系结构方面提供了一种快速的解决方案…

总线设备驱动框架

1.platform_device&#xff1a;修改设备树&#xff0c;添加设备&#xff08;device&#xff09;节点&#xff0c;设备树节点部分会被转换为 platform_device。 2.platform_driver&#xff1a; 首先定义入口&#xff0c;出口函数&#xff1b;构建platform_driver结构体&#xf…

和解费用3362万美元,谁来守护跨境卖家的“钱包”

公司向原告支付3362万美元(包括原告方主张的损害赔偿金2500万美元及原告方支付的律师费用862万美元)&#xff1b; 公司不得通过任何方式访问或使用原告的产品或数据&#xff1b; 公司不得向最终用户提供维修帮助服务(属于公司汽车诊断产品中的辅助维 修功能&#xff0c;不影响…

MTLAB 批量下载 脑医学图像数据集BrainWeb: Simulated Brain Database

MTLAB 批量下载 脑医学图像数据集BrainWeb: Simulated Brain Database BrainWeb数据集的网址&#xff1a;https://brainweb.bic.mni.mcgill.ca/brainweb/ 1. 了解 BrainWeb: Simulated Brain Database 这是一个模拟大脑数据的数据库&#xff08;SBD&#xff0c;Simulated Br…

C#重新认识笔记_ 点乘,叉乘

C#重新认识笔记_ 点积&#xff0c;叉乘 一、Dot Product 点乘&#xff1a; &#xff08;Ax*Bx&#xff09;&#xff08;Ay*By&#xff09;&#xff08;Az*Bz&#xff09;Dot Product 点积 利用点积&#xff0c;可以了解&#xff0c;两个向量(vector)的相关信息&#xff0c; …

【系统架构设计师】软件架构设计 02

系统架构设计师 - 系列文章目录 01 系统工程与信息系统基础 02 软件架构设计 文章目录 系统架构设计师 - 系列文章目录 文章目录 前言 一、软件架构的概念 ★★★ 二、基于架构的软件开发 ★★★★ 三、软件架构风格 ★★★★ 1.数据流风格 2.调用/返回风格 3.独立构件风格…

python之json数据格式

json 本质上是一个字符串&#xff0c;有一些特定格式&#xff0c;且每一种编程语言偶有这种格式实现数据传输 #序列化 info{code:100,"data":1} import json data_stringjson.dumps(info) print(data_string) #{"code": 100, "data": 1} …

Qt学习--继承(并以分文件实现)

基类 & 派生类 一个类可以派生自多个类&#xff0c;这意味着&#xff0c;它可以从多个基类继承数据和函数。定义一个派生类&#xff0c;我们使用一个类派生列表来指定基类。类派生列表以一个或多个基类命名。 总结&#xff1a;简单来说&#xff0c;父类有的&#xff0c;子…

操作系统系列学习——信号量临界区保护

文章目录 前言信号量临界区保护 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招&#xff0c;计划学习操作系统并完成6.0S81&#xff0c;加油&#xff01; 本文总结自B站【哈工大】操作系统 李治军&#xff08;全32讲&#xff09; 老师课程讲的非常好&#xff0c;感谢 【哈…

【力扣精选算法100道】——带你了解(数组模拟栈)算法

目录 &#x1f4bb;比较含退格的字符串 &#x1f388;了解题意 &#x1f388;分析题意 &#x1f6a9;栈 &#x1f6a9;数组模拟栈 &#x1f388;实现代码 844. 比较含退格的字符串 - 力扣&#xff08;LeetCode&#xff09; &#x1f4bb;比较含退格的字符串 &#x1f3…

Maven项目 快速修复log4j 漏洞

1、log4j 漏洞介绍 log4j的漏洞介绍以及原理请参考文章 &#xff0c;网址详见下面文章 Log4j漏洞原理及修复_linux log4j漏洞修复方案-CSDN博客&#xff0c;遇到这个漏洞要升级log4j 的jar包到2.17.0 以上。 2、项目快速处理方案 由于maven 管理jar 的spring 项目或者…

通过点击按钮实现查看全屏和退出全屏的效果

动态效果如图&#xff1a; 可以通过点击按钮&#xff0c;或者esc键实现全屏和退出全屏的效果 实现代码&#xff1a; <template><div class"hello"><el-button click"fullScreen()" v-if"!isFullscreen">查看全屏</el-butt…

DevExpress WinForms crack,DevExpress WinForms组件套件和库

DevExpress WinForms crack,DevExpress WinForms组件套件和库 Reporting & Analytics - Reports, Pivot Tables, PDF Viewer. The DevExpress WinForms Subscription includes royalty-free user interface components for next-gen decision support systems. Whether you…

PTA模拟+数学分析

作者 李曲 单位 浙江工业大学 生物学家发现了一种奇怪的DNA分子&#xff0c;最好用集合{A&#xff0c;B}中的N个字符序列来描述。一个不太可能的突变序列导致了一条由A‟s组成的DNA链。生物学家发现这很奇怪&#xff0c;所以他们开始更详细地研究突变。 他们发现了两种类型的…

泡澡——前缀和

题目链接&#xff1a;1.泡澡 - 蓝桥云课 (lanqiao.cn) 主要应用前缀和方法解决问题 package lanqiao;import java.util.Scanner;/*** 2023/11/29*/ public class lanqiao3898_泡澡 {static final int MAX (int) 2e5;public static void main(String[] args) {Scanner scan ne…

KY198 找最小数

描述&#xff1a; 第一行输入一个数n&#xff0c;1 < n < 1000&#xff0c;下面输入n行数据&#xff0c;每一行有两个数&#xff0c;分别是x y。输出一组x y&#xff0c;该组数据是所有数据中x最小&#xff0c;且在x相等的情况下y最小的。 输入描述&#xff1a; 输入有多…