UPC训练赛二十/20240217

A:无穷力量

题目描述

2022年重庆突发山火让世界看到了中国一个又一个的感人事迹:战士们第一时间奔赴火场,志愿者们自发组成团队,为救火提供一切的可能的服务,人们自发输送物资,有的志愿者甚至几天几夜没有睡觉。每个人献出一点力,造就了集体的无穷力量。山火被灭后,记者想统计共有多少人志愿者参加了灭火行动,他在山脚共找到了N个不同的志愿者进行调查。这N个被调查的志愿者回答如下:
第1位志愿者回答:和我一起行动的,除了我之外,还有A[1]个人。
第2位志愿者回答:和我一起行动的,除了我之外,还有A[2]个人。
第3位志愿者回答:和我一起行动的,除了我之外,还有A[3]个人。
。。。。。。
第N位志愿者回答:和我一起行动的,除了我之外,还有A[N]个人。
假设这N位志愿者都没有记错,那么至少有多少志愿者参与了灭火?

输入

分两行输入。
第一行,一个整数N。
第二行,N个整数,空格分开,第i个整数表示A[i]。

输出

一个整数,表示至少有多少个志愿者。

样例输入 Copy
【样例1】
4
1 2 1 2
【样例2】
9
2 2 44 2 2 2 444 2 2
样例输出 Copy
【样例1】
5
【样例2】
499
提示

对于100%的数据,3<N<=50,0<=A[i]<=1000000。

#include <bits/stdc++.h>
using namespace std; 
map<int, int>mp;
int main()
{int n; cin >> n;for (int i = 1; i <= n; i++){int num;scanf("%d", &num); mp[++num]++;}int sum = 0;for (auto it : mp){sum += it.first;while (mp[it.first] > it.first){mp[it.first] -= it.first;sum += it.first;}}if (sum >= n) printf("%d\n", sum); else printf("%d\n", n); return 0;
}

B:幸运位置

题目描述

刀越磨越快,脑子越用灵。不管什么事情,小宏总是喜欢多思考。今天他和小伙伴们玩一个游戏:n个人围成一圈,从第1个位置开始报数,每隔m个人报一次数,每次报数的人要表演节目,这样很有可能有人不用表演节目。例如有6个人,每隔3报数,报数的位置则是:1、5、3、1、5、3……,这样位置2、4、6的人就不用表演节目。小宏想考考你:在玩游戏前,根据n和m,迅速找出这些不用表演节目的位置。

输入

共一行,两个整数:n和m。1<=n<=10000,  1<=m<=1000。

输出

共一行,不用表演节目的位置,如果所有位置都要表演节目,则输出”NO”。

样例输入 Copy
【样例1】
6 3
【样例2】
5 3
样例输出 Copy
【样例1】
2 4 6
【样例2】
NO
/*一个大佬的方法*/
#include<bits/stdc++.h>
using namespace std;
typedef long long int ll;
#define N 1000009
int arr[N];
int main()
{int n, m, i = 1, ans = 0;scanf("%d%d", &n, &m);while (arr[i] == 0){arr[i] = 1;i += (m + 1);if (i != n) i %= n;}for (int i = 1; i <= n; i++){if (arr[i] == 1) ans++;else printf("%d ", i);}if (ans == n) puts("NO");return 0;
}/*我的方法*/
#include <bits/stdc++.h>
using namespace std;
set<int>arr;
int main()
{int n, m;scanf("%d%d", &n, &m);int idx = 1, cntof1 = 0, cnt = 0;while (cntof1 < 2){cnt++;if (idx % n == 0) arr.insert(n);else arr.insert(idx % n);if (idx % n == 1) cntof1++;idx += m + 1;}if (arr.size() == n) printf("NO\n");elsefor (int i = 1; i <= n; i++){if (arr.find(i) == arr.end()) printf("%d ", i);}return 0;
}

G:智力测试题

题目描述

牛牛同学智商为-1e9,但是他既不谦虚又不低调,很喜欢炫耀他的智商。
现在,牛牛就来测智商了,题目是这样。
已知一个n乘以n的矩阵,有一个小球一开始在(1,1)处,小球每秒都会向右走一格,如果到达最右边,小球就会掉落在下一行的第一格。
如果到达(n, n)则返回(1,1)。现在给定n和时间t,请你输出小球最后所在的行和列。

输入

一行两个正整数,n和t。

输出

两个整数代表小球最终的行和列。

样例输入 Copy
【样例 1 输入】 
3 5 
【样例 2 输入】 
4 2 
【样例 3 输入】
2 7
样例输出 Copy
【样例 1 输出】 
2 3 
【样例 2 输出】 
1 3 
【样例 3 输出】
2 2
提示

【数据范围】
对于 50% 数据保证:t ≤ n2 − 1 对于

80% 数据保证:t ≤ n2 对于

100% 数据保证:1 ≤ n ≤ 10,0 ≤ t ≤ 500
题目数据比较毒瘤,请考虑所有情况。
 

#include <stdio.h>
int main()
{int n, t;scanf("%d%d", &n, &t);if (!((t / n + 1) % n)) printf("%d ", n);else printf("%d ", (t / n + 1) % n);printf("%d\n", 1 + t % n);return 0;
}

 H:采集灵石

题目描述

牛牛打开了一个有趣的游戏。在游戏中,灵石是一种非常重要的资源。每位玩家每天有且仅有一次采集的机会。

灵石会在许多浮岛上刷新,每个浮岛上灵石刷新数量可能不同。这些浮岛之间通过传送法阵相连,激活每个岛屿上的传送法阵花费的灵石数量也不同。玩家可以耗费mi 块灵石从任意一个其他浮岛或初始平台前往第i个浮岛。采集完毕后玩家

可以从任何浮岛直接退出地图。

现在,牛牛手中有着K块灵石,他想知道自己今天采集结束后最多能拥有多少块灵石。牛牛只能在周末玩一小时游戏,他希望你能编写一个程序帮他及时算出来。 

输入

第一行两个正整数N, K分别表示浮岛的数量和牛牛手中初始的灵石数量。
接下来N行,每行两个正整数ki, mi,第i行的正整数ki表示第i个浮岛上今日刷新的灵石数量,mi表示传送到第i个浮岛所需的灵石数量。

输出

一个正整数,表示牛牛今天采集后最多能拥有的灵石数量。

样例输入 Copy
【样例 1 输入】
3 5
4 3
4 3
4 3
【样例 2 输入】
2 1
5 2
8 2
【样例 3 输入】
2 6
2 3
4 3
样例输出 Copy
【样例 1 输出】
8
【样例 2 输出】
1
【样例 3 输出】
7
提示

【数据范围】
对于 30% 的数据,满足 ki > mi
对于 100% 的数据,满足0 < N, K ≤ 105, 0 < ki, mi ≤ 109
保证答案在int范围内。

#include <bits/stdc++.h>
#pragma GCC optimize(2)
using namespace std;
priority_queue< pair<int,int>,vector<pair <int,int> >, greater< pair<int,int> > > q;
const int N = 1e5 + 10;
int k[N], m[N];
int main()
{int n,K;cin >> n >> K;while(n--){int x,y;scanf("%d%d",&x,&y);if(x > y) q.push(make_pair(y,x));}while(q.size()!=0){auto t = q.top();int y = t.first;int x = t.second;if(K >= y){K += x - y;q.pop();}else{break;}}cout << K << endl;return 0;
}

I:跳跃的排列

题目描述

小 B 很喜欢排列,这次他有一个长为n的排列 a1, a2, ⋯ , an。由于他音游玩多了,所以他想让排列也跳跃起来。他定义一次排列的跳跃为:

令 bi 表示最大的j (i ≤ j ≤ n)满足 aj ≥ ai,则bi= aj。最后对于所有i = 1 ∼ n,将 ai赋值为bi。  

他想重复上述操作若干次。若操作k次和操作k + 1次序列保持不变,那么跳跃停止,跳跃次数为k。他想知道排列会跳跃多少次,请你来帮他计算一下。   

输入

第一行, 输入一个数n。第二行输入n个数,第i个数表示ai。

输出

输出排列的跳跃次数。

样例输入 Copy
【样例 1 输入】
4
4 1 3 2
【样例 2 输入】
10
1 9 2 6 8 7 4 3 5 10
【样例 3 输入】
8
8 7 6 5 4 3 2 1
样例输出 Copy
【样例 1 输出】
1
【样例 2 输出】
1
【样例 3 输出】
0
提示

【样例 1 说明】 经过1轮操作后,序列变成4 2 3 2,经过2轮操作后,序列仍然是4 2 3 2,因此排 列跳跃了1次。
【样例 2 说明】 经过1轮操作后,所有数都变成了10,经过2轮操作后,序列仍然全都是10,因此 排列跳跃了1次。
【样例 3 说明】 经过1轮操作后,序列仍然是8 7 6 5 4 3 2 1,因此排列没有进行跳跃。

【数据范围】
对于奇数编号的数据,满足给定的排列形如n, n − 1, ⋯ ,1或1,2, ⋯ , n。

对于30%的数据,1 ≤ n ≤ 1000;
对于70%的数据,1 ≤ n ≤ 105;
对于100%的数据,1 ≤ n ≤ 106。

#include<bits/stdc++.h>
using namespace std;
const int N = 1e6 + 10;
int a[N], b[N];
int main()
{int n;cin >> n;for (int i = 1; i <= n; i++) scanf("%d", &a[i]);b[1] = a[1];for (int i = 2; i <= n; i++){if (b[i - 1] >= a[i]) b[i] = a[i];else b[i] = b[i - 1];}// b数列实时存储当前a数列中的最小值if (a[n] <= b[n]) puts("0"); // j要取最大值,看最右端。也就是,// 当a里面的数连最小值都不如的时候,就没法再替换了,故输出0else puts("1");// 反之return 0;
}

 K:最接近

小明同学最近正在研究一些幂次的特性,比如 3^2 = 9 和 4^3 = 64。小花是小明的好朋友,她总是和小明一起学习,由于小花刚刚学习幂次,很多计算还不太熟练。她很好奇,对于任意给出的正整数 N,不超过 的最大的 2 的幂次方的数是多少?例如:如果 等于 10,那么不超过 10 的最大的 2 的幂次方的整数就是 8,如果 是 100,那么不超过 100 的最大的 2 的幂次方的整数就是 64。小花希望你能帮助她解决这个问题。如果你能解决这个问题,就能和小花成为好朋友,小花希望朋友越多越好。

输入只有一行一个正整数 N

输出只有一行一个正整数,表示不超过 的最大的 2 的幂次方的正整数。

样例1 input 10 output 8

样例2 input 100 output 64

1<=N<=1e18;

#include <bits/stdc++.h>
using namespace std;
int main()
{long long n;cin >> n;long long L = 1,  R = 63;while (L <=  R){long long mid = (L + R) >> 1;long long ans = pow(2, mid);if (ans > n) R = mid;else if (ans < n){if (pow(2, mid + 1) > n){cout << ans;break;}L = mid + 1;}else{cout << ans;break;}}return 0;
}

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

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

相关文章

反射的作用

获取一个类里面所有的信息&#xff0c;获取到了之后&#xff0c;再执行其他的业务逻辑结合配置文件&#xff0c;动态的创建对象并调用方法 练习1&#xff1a; public class MyTest {public static void main(String[] args) throws IllegalAccessException, IOException {Stude…

Swift 5.9 新 @Observable 对象在 SwiftUI 使用中的陷阱与解决

概览 在 Swift 5.9 中&#xff0c;苹果为我们带来了全新的可观察框架 Observation&#xff0c;它是观察者开发模式在 Swift 中的一个全新实现。 除了自身本领过硬以外&#xff0c;Observation 框架和 SwiftUI 搭配起来也能相得益彰&#xff0c;事倍功半。不过 Observable 对象…

C++学习Day06之继承方式

目录 一、程序及输出1.1 公共继承1.1.1 父类中公共成员&#xff0c;子类可以正常访问1.1.2 父类中保护成员&#xff0c;子类类外不可以访问1.1.3 父类中私有成员&#xff0c;子类无法访问 1.2 保护继承1.2.1 父类中公共权限 子类中变为 保护权限1.2.2 父类中保护权限 子类中变为…

自定义Linux登录自动提示语

设置提示语的方式 在Linux系统中&#xff0c;可以通过修改几个特定的文件来实现在用户登录时自动弹出提示语。以下是几个常用的方法&#xff1a; 1. 修改/etc/issue文件&#xff1a; 这个文件用于显示本地登录前的提示信息 sudo vi /etc/issue在项目合作的时候&#xff0c;…

平衡二叉树(AVL树)

定义&#xff1a; 左右子树高度之差不超过1左右子树都是平衡二叉树 平衡二叉树的增删操作都离不开二叉树的调整 二叉树调整 LL型&#xff1a;右旋 LR型&#xff1a;左旋右旋 RR型&#xff1a;左旋 RL型&#xff1a;右旋左旋

从小红书笔记详情API看电商如何提升品牌影响力

从小红书笔记详情API来看&#xff0c;电商如何提升品牌影响力是一个复杂但至关重要的过程。首先&#xff0c;理解小红书平台和其用户群体的特点是关键。小红书是一个以用户分享和消费体验为主的社交媒体平台&#xff0c;用户群体主要是年轻、有购买力的女性。因此&#xff0c;电…

Python 遍历结构复杂的多层嵌套字典,收集特定键值对

可以使用递归函数来遍历整个嵌套层次不同的字典&#xff0c;收集所有感兴趣的键值对&#xff0c;最终得到一个非嵌套结构的字典&#xff1a; &#xff08;一般用于处理爬取的json数据&#xff0c;因为有些结构真的蛮怪的(&#xff92;3[____] def extract_key_value_pairs(ne…

FPFH特征描述符、对应关系可视化以及ICP配准

一、FPFH特征描述符可视化 C #include <pcl/point_types.h> #include <pcl/point_cloud.h> #include <pcl/search/kdtree.h> #include <pcl/io/pcd_io.h> #include <pcl/features/normal_3d_omp.h>//使用OMP需要添加的头文件 #include <boo…

批量追踪中通快递

在物流信息的管理中&#xff0c;批量追踪中通快递单号一直是个让人头疼的问题。但有了固乔快递查询助手&#xff0c;这一切都变得轻而易举。 固乔快递查询助手&#xff0c;作为市场上备受好评的快递查询软件&#xff0c;专门针对批量查询需求进行了优化。用户只需将中通快递单号…

【Linux】简单的网络计算器的实现(自定义协议,序列化,反序列化)

文章目录 前言一、 服务端1.ServerCal.cc&#xff08;服务器主文件&#xff09;2.ServerCal.hpp3.Sock.hpp(套接字封装)4.TcpServer.hpp(服务器)5.Protocol&#xff08;自定义协议&#xff09; 二、用户端1.ClientCal 三、Log.hpp&#xff08;日志&#xff09;四、makefile 前言…

【Qt学习】QIcon类 + 利用qrc机制设置图片路径(QtCreator)

文章目录 1. QIcon / windowIcon2. setIcon() 与 setwindowIcon()2.1 setIcon() 介绍与使用2.2 setWindowIcon 介绍与使用 3. 路径问题 & qrc机制的引入3.1 绝对路径 / 相对路径 的问题3.2 qrc机制3.3 在QtCreator下利用qrc机制引入图片 1. QIcon / windowIcon QIcon QIco…

【C语言】如何处理输入值为-1的情况?

一、问题 很多情况下&#xff0c;代码将输入-1作为输入动作的结束&#xff0c;那么如果数据真的是个-1&#xff0c;怎么办? 如果数据真的是-1&#xff0c;并且-1是用来表示输入动作的结束&#xff0c;那么需要找到解决方案来区分真实的-1数据和表示结束的-1。 另一种方法是使用…

探索递归的无限魅力——一次充满惊喜的迷之旅程

在计算机科学的世界里&#xff0c;递归是一个强大而神奇的工具。它可以让问题化繁为简&#xff0c;以一种优雅而富有创造力的方式解决各种棘手的难题。递归看似简单&#xff0c;却蕴含着无尽的探索和乐趣。 让我们开始这次迷之旅程吧&#xff01;想象一下你正站在一个迷宫中央…

单输入Doherty 功率放大器的极限带宽分析(含Matlab分析代码)

单输入Doherty 功率放大器的极限带宽分析&#xff08;含Matlab分析代码&#xff09; 参考论文&#xff1a;高效连续型射频功率放大器研究 DPA的基础理论参考&#xff1a;理想架构的Doherty功率放大器理论与仿真 1、单输入Doherty 功率放大器架构 假设 Doherty 功率放大器的…

介绍7款免费的最佳地图/导航/定位/GIS开源项目

文章目录 1、xdh-map新德汇地图应用类库1.1、独立引用1.2、与MyUI结合使用1.3、快速上手1.3.1、采用项目工程模板创建项目【推荐】1.3.2、 调用组件库功能 2、蚂蚁金服AntV-L7地理空间数据可视分析引擎2.1、AntV-L7简介2.2、核心特性2.3、支持丰富的图表类型2.4、如何使用2.4.1…

BLHeli_S 代码分析—BLHeli.asm函数 init_start_bidir_done 分析

BLHeli_S 代码分析—BLHeli.asm函数init_start_bidir_done分析 init_start_bidir_done代码 代码中数据变量定义 Flags1: DS 1 ; 状态标志. Reset upon init_start 初始化启动时重置 MOTOR_SPINNING EQU 0 ; 电机旋转标志 STARTUP_PHASE EQU 1 ; 启动相位标志Startup_…

反转一个单链表

反转一个单链表 题意&#xff1a;反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 思路 需要虚拟节点么&#xff1f; 答&#xff1a;不需要&#xff0c;因为没有删除节点&#xff0c;只是改变了节点的指向。 遍…

STM32-开发环境之STM32CubeMX

目录 STM32CubeMX介绍 STM32CubeMX特性 应用场景 其他事项 STM32CubeMX介绍 STM32CubeMX是ST公司&#xff08;意法半导体&#xff09;推出的一款图形化工具&#xff0c;也是配置和初始化C代码生成器。它主要服务于STM32微控制器的配置和开发。 STM32CubeMX特性 1.直观选…

计算机设计大赛 深度学习二维码识别

文章目录 0 前言2 二维码基础概念2.1 二维码介绍2.2 QRCode2.3 QRCode 特点 3 机器视觉二维码识别技术3.1 二维码的识别流程3.2 二维码定位3.3 常用的扫描方法 4 深度学习二维码识别4.1 部分关键代码 5 测试结果6 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天…

Rust-知多少?

文章目录 前言1.使用下划线开头忽略未使用的变量2. 变量解构3.常量4.变量遮蔽&#xff08;shadowing&#xff09;5. 类似println!("{}", x); 为啥加感叹号6.单元类型总结 前言 Rust 学习系列&#xff0c;记录一些rust使用小技巧 1.使用下划线开头忽略未使用的变量 …