2024.3.21|华北水利水电大学江淮校区ACM社团训练赛

2024.3.21|华北水利水电大学江淮校区ACM社团训练赛

1.数字拆解
2.矩阵修改
3.因子数
4.回文数
5.中位数

心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。
在这里插入图片描述

数字拆解

题目
小红拿到了一个偶数,她希望你将其切割成尽可能多的偶数。你能帮帮她吗?
输入描述:
一个偶数
1≤x≤105
输出描述:
输出若干行,从小到大输出每个偶数。
示例1
输入
1024
输出
2
4
10
说明
拆分成"10"+“2”+"4"三个偶数。
示例2
输入
999999999999999999999999990
输出
999999999999999999999999990
示例3
输入
202020
输出
0
0
0
2
2
2
注意
自己看数据范围,用string吧孩子,然后还需要一个动态字符串t去切割、连接和存储,判断是不是偶数你就看这个数最末位能不能对2取余等不等于0就完了。对2取余为0的数有0,2,4,6,8。

实践代码:

bool cmp(string a,string b){if(a.size()!=b.size()) return a.size()<b.size();return a<b;
}
void solve(){string s;cin>>s;string t;vector<string> a;for(int i=0;i<s.length();i++){t+=s[i];int y=s[i]-'0';if(y%2==0) {a.push_back(t);t="";}}sort(a.begin(),a.end(),cmp);for(int i=0;i<a.size();i++) cout<<a[i]<<endl;
}

矩阵修改

题目
小红拿到了一个字符矩阵,矩阵中仅包含"red"这三种字符。
小红每次操作可以将任意字符修改为"red"这三种字符中的一种。她希望最终任意两个相邻的字母都不相同。小红想知道,至少需要修改多少个字符?
输入描述:
第一行输入两个正整数n,m,代表矩阵的行数和列数。
接下来的n行,每行输入一个长度为m的、仅由"red"这三种字符组成的字符串。
1≤n≤4
1≤m≤1000
输出描述:
一个整数,代表需要修改的字母数量的最小值。
示例1
输入
2 3
ree
dee
输出
2
说明:
修改为:
red
dre
即可。

注意
三进制状压dp。

实践代码:


因子数

题目
给出一个质数 n,请求出一个质数 m,使得 n+m 不是质数。
其中,质数是指大于 1 的自然数,除了 1 和自身外,不能被其他自然数整除的数。
输入描述:
仅输入一行,包含一个整数 n(2≤n≤2⋅105 ),保证 n 是质数。
输出描述:
仅输出一行。包含一个质数 m(2≤m≤2⋅105 ),表示答案。
如果有多个可行的答案,请输出任意一个。
可以证明,在题目所给条件下一定有解。
示例1
输入
11
输出
3

### 实践代码:
void solve(){int x;cin>>x;if(x==1) {cout<<0;return;}int cnt=0;for(int i=2;i<x/i;i++){if(x%i==0){cnt++;while(x%i==0) x/=i;//排除9=3*3这种质因子相同情况}}if(x>1) cnt++;cout<<cnt;
}

回文数

如果一段序列区间是回文的,有两种情况:
1.长度为偶数时,证明区间里的数字是一一对应的,即里面的数字0-9中的每个数的数量是偶数个。
2.长度是奇数时,证明除了中间那个数字之外的数字是一一对应的,即对于数字0-9来说里面有且仅有一个数字的数量是奇数,剩下都必须是偶数个。

题目
小红定义一个整数是“好数”,当且仅当该整数通过重排之后可以形成回文数。(可以包含前导零)
现在小红拿到了一个正整数x,小红想截取一段连续区间得到好数,她想知道有多少种不同的方案?
输入描述:
输入一个正整数1≤x≤105
输出描述:
得到“好数”的方案数。
示例1
输入
110
输出
5
说明
长度为 1 的区间,三个都是合法的。
长度为 2 的区间,"11"是合法的,"10"是不合法的。
长度为 3 的区间, "110"是合法的。

实践代码:

map<vector<int>,int> mp;
vector<int> cnt(10,0);//cnt[i] - i(0~9)这个数字出现了几次(这里只需记录奇/偶个) 1-奇数个 0-偶数个
void solve(){string s;cin>>s;mp[cnt]++;//初始化为0,即0~9的数字都没出现过,都是偶数int ans = 0;for(int i=0;i<s.length();i++){cnt[s[i]-'0']^=1;//开始为0 异或1为1(奇数个) 之后再出现异或1为0(偶数个)ans+=mp[cnt];//加上和它完全一样的区间数for(int j=0;j<10;j++){//统计只有一个数字出现次数不一样的区间vector<int> tmp;tmp=cnt;tmp[j]^=1;ans+=mp[tmp];}mp[cnt]++;//每次结束之后 这个区间数+1}

中位数

计算中位数的步骤如下:
首先,将所有数据按照大小顺序排列。
如果数据数量是奇数,那么中位数就是排序后的中间数值
如果数据数量是偶数,那么中位数是排序后中间两个数的平均值

题目
小红拿到了一个数组:a1 ,a2 ,…,an。她定义 f(i) 为,删除第i个元素后,数组的中位数。现在小红想让你求出f(1),f(2)…f(n)的值,你能帮帮她吗?
输入描述:
第一行输入一个正整数n,代表数组的大小。
第二行输入n个正整数ai,代表数组的元素。
2≤n≤105
1≤ai≤109
输出描述:
输出n行,每行输出一个浮点数,第i行代表f(i)的值。保留一位小数。
示例1
输入
4
2 5 8 1
输出
5.0
2.0
2.0
5.0
示例2
输入
3
1 2 3
输出
2.5
2.0
1.5

实践代码:

void solve(){int n;cin>>n;vector<int> a(n),b(n);for(int i=0;i<n;i++) {cin>>a[i];b[i]=a[i];}sort(b.begin(),b.end());if(n%2==0){//即删一个数后数列个数为奇数情况int t1=b[n/2-1],t2=b[n/2];for(int i=0;i<n;i++){if(a[i]<t2) printf("%.1f\n",t2*1.0);else printf("%.1f\n",t1*1.0);}}else{//即删一个数后数列个数为偶数的情况int t1=b[n/2-1];int t2=b[n/2];int t3=b[n/2+1];for(int i=0;i<n;i++){if(a[i]<t2) printf("%.1f\n",(t2+t3)/2.0);if(a[i]>t2) printf("%.1f\n",(t1+t2)/2.0);else if(a[i]==t2)printf("%.1f\n",(t1+t3)/2.0);}}
}

心有猛虎,细嗅蔷薇。再见了朋友~

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

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

相关文章

通俗易懂:如何通过JVM参数来调整内存大小?

调整Java虚拟机&#xff08;JVM&#xff09;的内存大小主要是为了优化应用程序性能&#xff0c;防止内存不足而导致的OutOfMemoryError异常。以下是一些关键的JVM参数用于调整内存大小&#xff1a; 1. 堆内存&#xff08;Heap Memory&#xff09; - -Xms&#xff1a;设置JVM的初…

【联邦学习】kubefate安装(docker-compose版)

概念介绍 联邦学习&#xff1a;&#xff08;待补充&#xff09; fate介绍&#xff1a;&#xff08;待补充&#xff09; kubefate介绍&#xff1a;分布式版fate 官网&#xff1a;https://fate.fedai.org/ github&#xff1a;https://github.com/FederatedAI/ 安装 背景 本文…

springboot+vue在idea上面的使用小结

1.在mac上面删除java的jdk方法&#xff1a; sudo rm -rfjdk的路径 sudo rm -rf /Users/like/Library/Java/JavaVirtualMachines/corretto-17.0.10/Contents/Home 2.查询 Mac的jdk版本和路径&#xff1a; /usr/libexec/java_home -V 3.mac上面查询和关闭idea的网页端口&…

快速上手Spring Cloud五:Spring Cloud与持续集成/持续部署(CI/CD)

快速上手Spring Cloud 一&#xff1a;Spring Cloud 简介 快速上手Spring Cloud 二&#xff1a;核心组件解析 快速上手Spring Cloud 三&#xff1a;API网关深入探索与实战应用 快速上手Spring Cloud 四&#xff1a;微服务治理与安全 快速上手Spring Cloud 五&#xff1a;Spring …

samba实现linux共享文件夹

一、samba安装 sudo apt install samba 二、配置Samba 编辑Samba配置文件sudo vi /etc/samba/smb.conf 在文件末尾添加以下内容&#xff0c;设置一个简单的共享目录&#xff08;替换path_to_share为实际的共享目录路径&#xff09;&#xff1a; [Share] path /path_to_sha…

鱼眼相机的测距流程及误差分析[像素坐标系到空间一点以及测距和误差分析]

由于最近在整理单目测距的内容&#xff0c;顺手也总结下鱼眼相机的测距流程和误差分析&#xff0c;如果有错误&#xff0c;还请不吝赐教。 参考链接: 鱼眼镜头的成像原理到畸变矫正&#xff08;完整版&#xff09; 相机模型总结&#xff08;针孔、鱼眼、全景&#xff09; 三维…

多模态系列-综述MM-LLMs: Recent Advances in MultiModal Large Language Models

Homepage:https://mm-llms.github.io/ Paper: https://arxiv.org/abs/2401.13601 1 摘要 在过去的一年中,多模态大型语言模型(MM-LLMs)取得了实质性的进展,通过高效的训练策略,增强了现成的语言模型,以支持多模态输入或输出。由此产生的模型不仅保留了语言模型的固有…

Unity照片墙简易圆形交互效果总结

还要很多可以优化的点地方&#xff0c;有兴趣的可以做 比如对象的销毁和生成可以做成对象池&#xff0c;走到最左边后再移动到最右边循环利用 分析过程文件&#xff0c;采用Blender&#xff0c;资源已上传&#xff0c;可以播放动画看效果&#xff0c;下面截个图&#xff1a; …

关系型数据库mysql(8)sql高级语句②

目录 一.子查询——Subquery 语法 环境准备 In——查询已知的值的数据记录 子查询——Insert 子查询——Update 子查询——Delete Not In——表示否定&#xff0c;不在子查询的结果集里 Exists——判断查询结果集是否为空 子查询——别名 ​编辑 二.视图 理论&a…

图论之路径条数专题

一直忙着金工实习蓝桥杯&#xff0c;好久没有看图论了&#xff0c;今天就小试几题享受下被虐的快感。 1.最短路拓扑 首先来几个结论&#xff1a; 1.最短路图没有环&#xff08;可以用反证法证明&#xff09; 2.dis[u]edge[u,v]dis[v]&#xff0c;那么u,v端点的边一定在最短路…

方差分析(ANOVA)

方差分析&#xff08;ANOVA&#xff0c;Analysis of Variance&#xff09;是一种统计方法&#xff0c;用于比较两个或多个组之间的平均数是否存在显著差异。其原理基于对总方差的分解&#xff0c;将总方差分解为组内方差和组间方差。通过比较组内方差和组间方差的大小&#xff…

selenium自动化测试

selenium自动化测试 1、Javaselenium环境搭建2、测试&#xff0c;打开任意网页3、selenium 常见的Api3.1元素定位findElement3.1.1 css 选择语法3.1.2 xpath 选择语法 1、Javaselenium环境搭建 下载chromedriver&#xff0c;版本要与Chrome浏览器版本一致。 下载之后将chro…

数据库【QSqlQueryaModel】

QSqlQueryModel Class 描述 QSqlQueryModel是用于执行SQL语句和遍历结果集的高级接口。它构建在较低级别的QSqlQuery之上&#xff0c;可用于为视图类&#xff08;如QTableView&#xff09;提供数据。例如 QSqlQueryModel *model new QSqlQueryModel;model->setQuery(&quo…

C++经典面试题目(九)

1、什么是组合&#xff1f;请举例说明如何在C中实现组合。 组合是一种面向对象编程中的概念&#xff0c;用于描述类之间的关系。它表示一个类包含另一个类的对象作为成员变量的情况。在组合中&#xff0c;一个类的对象可以包含其他类的对象&#xff0c;这种关系通常表现为“拥…

第P1周:实现mnist手写数字识别

>- **&#x1f368; 本文为[&#x1f517;365天深度学习训练营](https://mp.weixin.qq.com/s/0dvHCaOoFnW8SCp3JpzKxg) 中的学习记录博客** >- **&#x1f356; 原作者&#xff1a;[K同学啊 | 接辅导、项目定制](https://mtyjkh.blog.csdn.net/)** 目录 一、前言 二、我…

Docker版本:18.06.1安装

1、操作系统&#xff1a;CentOS 7.5以上 2、Docker版本&#xff1a;18.06.1 1、解压 tar -xvf docker-18.06.1-ce.tgz2、将解压出来的docker文件内容移动到 /usr/bin/ 目录下 cp docker/* /usr/bin/3、将docker注册为service vim /etc/systemd/system/docker.service将下列…

vant checkbox 复选框 样式改写

修改前 修改后 基于 vant&#xff1a; 4.8.3 unocss: 0.53.4 <van-checkbox-group v-model"query.zczb" shape"square" class"text-16 w-100% flex flex-wrap"><template v-for"item in registerCapitalOption"><v…

LeetCode 27 移除元素

给你一个数组 nums 和一个值 val&#xff0c;你需要 原地 移除所有数值等于 val 的元素&#xff0c;并返回移除后数组的新长度。 不要使用额外的数组空间&#xff0c;你必须仅使用 O(1) 额外空间并 原地 修改输入数组。 元素的顺序可以改变。你不需要考虑数组中超出新长度后面…

“预防儿童烧烫伤”科普安全课堂走进嘉鱼县第一小学

为提高嘉鱼县儿童烧烫伤安全意识、隐患识别能力以及突发应急处置能力&#xff0c;3月26日下午&#xff0c;在中国社会福利基金会烧烫伤关爱公益基金、嘉鱼县妇女联合会、嘉鱼县教育局的支持下&#xff0c;嘉鱼县蒲公英社会工作服务中心走进嘉鱼县第一小学开展预防儿童烧烫伤科普…

go中的context超时控制、超时传递、跨进程超时传递

context包中的WithCancel、WithDeadline和WithTimeout函数提供了创建上下文&#xff08;context&#xff09;对象的能力&#xff0c;这些上下文对象对于管理goroutine的生命周期非常重要&#xff0c;尤其是在处理取消、超时和截止时间的场景中。 WithCancel WithCancel函数返回…