2021ICPC四川省赛个人补题ABDHKLM
Dashboard - The 2021 Sichuan Provincial Collegiate Programming Contest - Codeforces
过题难度:
A K D M H B L
铜奖 5 594
银奖 6 368
金奖 8 755
codeforces.com/gym/103117/problem/A
模拟出牌的过程,打表即可
// Code Start Here int t;cin >> t;while(t--){int n;cin >> n;if(n == 1)cout << 0 << endl;else if(n == 2) cout << 1 <<endl;else if(n == 3)cout << 1 <<endl;else if(n == 4)cout << 2 <<endl;else if(n == 5)cout << 2 <<endl;else if(n == 6)cout << 3 <<endl;else if(n == 7)cout << 3 <<endl;else if(n == 8)cout << 3 <<endl;else if(n == 9)cout << 2 <<endl;else if(n == 10)cout << 2 <<endl;else if(n == 11)cout << 1 <<endl;else if(n == 12)cout << 1 <<endl;else cout << 0 << endl;}
Problem - K - Codeforces
我们发现最优解肯定是间隔是K的尽量在一起,模拟即可
int n , k;cin >> n >> k;if(k >= n){for(int i = 1;i<n;i++)cout << i << " ";cout << n << endl;}else{vector<bool> vis(n + 1, false);vector<int> ans;for(int i = 1;i<=n;i++){if(!vis[i]){vis[i] = true;for(int j = i;j<=n;j += k){ans.push_back(j);vis[j] = true;}}}for(int i = 0;i<(int)(ans.size())-1;i++){cout << ans[i] << " "; }cout << ans.back() << endl;}
Problem - D - Codeforces
模拟剪刀石头布即可
int a1,b1,c1,a2,b2,c2;cin>>a1>>b1>>c1>>a2>>b2>>c2;int sum=0;int min1=min(a1,b2);sum+=min1;a1-=min1;b2-=min1;min1=min(b1,c2);sum+=min1;b1-=min1;c2-=min1;min1=min(c1,a2);sum+=min1;c1-=min1;a2-=min1;min1=min(a1,a2);a2-=min1;min1=min(b1,b2);b2-=min1;min1=min(c1,c2);c2-=min1;int p=0;p=max(a2,b2);p=max(p,c2);sum-=p;cout<<sum<<endl;
codeforces.com/gym/103117/problem/M
我们考虑整个扩张的过程,在0 ~ p0内的扩张肯定优先走0~p0,而在0~p0外的扩张对于1e5 * 1e5不现实,考虑优化,只保留一个最大的区间,如果这个区间可以通过,那么一定存在答案
int n , k , x , p0;cin >> n >> k >> x >> p0;vector<int> v(n + 1);for(int i = 1;i<=n;i++)cin >> v[i];vector<int> l(k+1),r(k+1);for(int i = 1;i<=k;i++)cin >> l[i];for(int i = 1;i<=k;i++)cin >> r[i];int max_val = -1;for(int i = 1;i<=k;i++){if(l[i] >= p0){max_val = max(max_val , r[i] - l[i]);}}int max_time = max(p0 , max_val);int ans = 0;for(int i = 1;i<=n;i++){if(v[i] * max_time >= x)ans++;}cout << ans << endl;
codeforces.com/gym/103117/problem/H
大模拟
string s;cin >> s;string now = "";// 构造 imasuif(!s.empty()) now += s.back() , s.pop_back();if(!s.empty()) now += s.back() , s.pop_back();if(!s.empty()) now += s.back() , s.pop_back();if(!s.empty()) now += s.back() , s.pop_back();if(!s.empty()) now += s.back() , s.pop_back();reverse(now.begin(),now.end());if(now != "imasu")cout << s << now << endl;else{char ch2 , ch1;if(!s.empty())ch2 = s.back() , s.pop_back();if(!s.empty())ch1 = s.back() , s.pop_back();if(ch1 == 'c' && ch2 == 'h'){cout << s << "tte" << endl;return;}if(ch1 == 's' && ch2 == 'h'){cout << s << "shite" << endl;return;}if(ch1 == 'i' && ch2 == 'k' && s.empty()){cout << s << "itte" << endl;return;}if(ch1 == 'i' && ch2 == 'k' && !s.empty()){cout << s << "iite" << endl;return;}if(ch2 == 'r'){cout << s << ch1 << "tte" << endl;return ;}if(ch2 == 'm' || ch2 == 'b' || ch2 == 'n'){cout << s << ch1 << "nde" << endl;return;}if(ch2 == 'k'){cout << s << ch1 << "ite" << endl;return;}if(ch2 == 'g'){cout << s << ch1 << "ide" << endl;return;}cout << s << ch1 << ch2 << now << endl;
Problem - B - Codeforces
考虑从奇偶性入手来找回合数,特别要注意的是如果一开始为0的话那么后面无法进行,需要特判
int n,m,k;cin>>n>>m>>k;for(int i=1;i<=n;i++){cin>>a[i];}int sum1=k/n;int sum2=k%n;vector<int>pre(m+1),last(m+1);map<int,int>p;vector<int>sum(n+1);
// cout<<sum1<<endl;if(sum1==0){map<int,int>p3;for(int i=1;i<=sum2;i++){if(p3[a[i]]){sum[i]++;p3[a[i]]--;continue;}p3[a[i]]++;}for(int i=1;i<n;i++){cout<<sum[i]<<' ';}cout<<sum[n]<<endl;return ;}for(int i=1;i<=n;i++){p[a[i]]++;if(p[a[i]]==1){pre[a[i]]=i;}last[a[i]]=i;}map<int,int>p4;for(int i=1;i<=n;i++){p4[a[i]]++;if(p[a[i]]%2==0){if(p4[a[i]]%2==0){sum[i]+=sum1;}}else{if(p[a[i]]==1){sum[i]+=sum1/2;}else{if(sum1&1){if(p4[a[i]]&1){sum[i]+=sum1/2;}else{sum[i]+=sum1/2+1;}}else{sum[i]+=sum1/2;}}}}map<int,int>p2;for(int i=1;i<=sum2;i++){p2[a[i]]++;if(p[a[i]]==1){if(sum1%2==0){continue;}else{sum[i]++;continue;}}if(p[a[i]]%2==1){if(sum1&1){if(p2[a[i]]%2==1){sum[i]++;continue;}else{continue;}}else{if(p2[a[i]]%2==0){sum[i]++;}continue;}}if(p2[a[i]]%2==0){sum[i]++;continue;}}for(int i=1;i<n;i++){cout<<sum[i]<<' ';}cout<<sum[n];cout<<endl;
https://codeforces.com/gym/103117/problem/L
按照权值分类,跑 100 次bfs,将题目给出的终点作为起点,将所有其他所有点作为终点。在符合条件的权值下找到最小值
vector<int>g[N];
vector<int>val[110];
int ans[110][N];
int vis[N];void bfs(int n){queue<pair<int, int>>q;for(int i=0; i<val[n].size(); i++){vis[val[n][i]] = 1;q.push(make_pair(val[n][i], 0));}while(q.size()){pair<int,int> x = q.front();q.pop();int now = x.first;ans[n][now] = x.second;for(int i=0; i<g[now].size(); i++){int nxt = g[now][i];if(vis[nxt]) continue;vis[nxt] = 1;q.push({nxt, x.second + 1});}}
}int32_t main(){int n, m, q, w = 0;cin >> n >> m >> q;for(int i=1; i<=n; i++){int a;cin >> a;w = max(a , w);val[a].push_back(i);}for(int i=0; i<m; i++){int a, b;cin >> a >> b;g[a].push_back(b);g[b].push_back(a);}for(int i=0; i<=w; i++) for(int j=0; j<=n; j++) ans[i][j] = n;for(int i=1; i<=w; i++){for(int j=0; j<=n; j++) vis[j] = 0;bfs(i);}while(q--){int a, b;cin >> a >> b;int x = n;for(int i=1; i<=b; i++) x = ans[i][a] < x ? ans[i][a] : x;if(x == n)cout << -1 << endl;else cout << x << endl;}return 0;
}
相关文章:
2021ICPC四川省赛个人补题ABDHKLM
Dashboard - The 2021 Sichuan Provincial Collegiate Programming Contest - Codeforces 过题难度: A K D M H B L 铜奖 5 594 银奖 6 368 金奖 8 755 codeforces.com/gym/103117/problem/A 模拟出牌的过程,打表即可 // Code Start Here int t…...

oracle linux 95 升级openssh 10 和openssl 3.5 过程记录
1. 安装操作系统,注意如果可以选择,选择安装开发工具,主要是后续需要编译安装,需要gcc 编译工具。 2. 安装操作系统后,检查zlib 、zlib-dev是否安装,如果没有,可以使用安装镜像做本地源安装&a…...
httpx[http2] 和 httpx 的核心区别及使用场景如下
httpx[http2] 和 httpx 的核心区别在于 HTTP/2 协议支持,具体差异及使用场景如下: 1. 功能区别 命令/安装方式协议支持额外依赖适用场景pip install httpx仅 HTTP/1.1无通用请求,轻量依赖pip install httpx[http2]支持 HTTP/2需安装 h2>3…...
Text models —— BERT,RoBERTa, BERTweet,LLama
BERT 什么是BERT? BERT,全称Bidirectional Encoder Representations from Transformers,BERT是基于Transformer的Encoder(编码器)结构得来的,因此核心与Transformer一致,都是注意力机制。这种…...

【AGI】大模型微调数据集准备
【AGI】大模型微调数据集准备 (1)模型内置特殊字符及提示词模板(2)带有系统提示和Function calling微调数据集格式(3)带有思考过程的微调数据集结构(4)Qwen3混合推理模型构造微调数据…...

新能源汽车制动系统建模全解析——从理论到工程应用
《纯电动轻卡制动系统建模全解析:车速-阻力拟合、刹车力模型与旋转质量转换系数优化》 摘要 本文以纯电动轻卡为研究对象,系统解析制动系统建模核心参数优化方法,涵盖: 车速-阻力曲线拟合(MATLAB实现与模型验证&…...
【Linux驱动】Linux 按键驱动开发指南
Linux 按键驱动开发指南 1、按键驱动开发基础 1.1. 按键驱动类型 Linux下的按键驱动主要有两种实现方式: 输入子系统驱动:最常用,通过input子系统上报按键事件 字符设备驱动:较少用,需要自己实现文件操作接口 1.…...
湖北理元理律师事务所:债务管理的社会价值探索
债务问题从来不是孤立的经济事件,其背后牵涉家庭稳定、社会信用体系乃至区域经济发展。湖北理元理律师事务所通过五年服务数据发现:科学债务规划可使单个家庭挽回约23%的可支配收入,间接降低离婚率、心理健康问题发生率等社会成本。 债务优化…...

【Bluedroid】蓝牙HID DEVICE 报告发送与电源管理源码解析
本文基于Android蓝牙协议栈代码,深度解析HID设备(如键盘、鼠标)从应用层发送输入报告到主机设备的完整流程,涵盖数据封装、通道选择、L2CAP传输、电源管理四大核心模块。通过函数调用链(send_report → BTA_HdSendRepo…...
04、基础入门-SpringBoot官方文档架构
04、基础入门-SpringBoot官方文档架构 # Spring Boot官方文档架构 Spring Boot官方文档是学习和使用Spring Boot的重要资源,其架构清晰,内容全面,帮助用户从入门到精通。以下是官方文档的主要架构: ## 1. 引言 - **关于文档**&…...

第9章 组件及事件处理
9.1 Java Swing概述 图像用户界面(GUI) java.awt包,即Java抽象窗口工具包,Button(按钮)、TextField(文本框)、List(列表) javax.swing包 容器类(…...
三、高级攻击工具与框架
高级工具与框架是红队渗透的核心利器,能够实现自动化攻击、权限维持和隐蔽渗透。本节聚焦Metasploit、Cobalt Strike及企业级漏洞利用链,结合实战演示如何高效利用工具突破防御并控制目标。 1. Metasploit框架深度解析 定位:渗透测试的“瑞…...

用golang实现二叉搜索树(BST)
目录 一、概念、性质二、二叉搜索树的实现1. 结构2. 查找3. 插入4. 删除5. 中序遍历 中序前驱/后继结点 一、概念、性质 二叉搜索树(Binary Search Tree),简写BST,又称为二叉查找树 它满足: 空树是一颗二叉搜索树对…...
10.13 LangChain工具调用实战:@tool装饰器+小样本提示,日处理10w+调用秘籍
LangChain 工具调用(Tool Calling)深度解析 关键词:LangChain工具调用, 函数调用与工具调用区别, @tool装饰器, ToolMessage机制, 小样本提示工程 1. Function Calling vs Tool Calling LangChain 中的工具调用系统经历了从函数调用(Function Calling)到工具调用(Tool …...
C++跨平台开发经验与解决方案
在当今软件开发领域,跨平台开发已成为一个重要的需求。C作为一种强大的系统级编程语言,在跨平台开发中扮演着重要角色。本文将分享在实际项目中的跨平台开发经验和解决方案。 1. 构建系统选择 CMake的优势 跨平台兼容性好 支持多种编译器和IDE 强大…...
【以及好久没上号的闲聊】Unity记录8.1-地图-重构与优化
最近几年越来越懒,要是能分身多好哇,大家教教我 懒得更CSDN了,所以不是很常上号,而CSDN的两周前私信显示的灰灰的 也就是虽然我每次上号都有看私信,但是搞笑的是前面四个明显的消息全是CSDN的广告,我压根没…...
C# 活动窗体截图:基于 Win32 API 的实现
1. 核心功能与技术栈 该截图功能类 ScreenShotClass 基于 Win32 API 实现了两种截图方式: CopyFromScreen 方法:利用 Graphics.CopyFromScreen 直接截取屏幕区域。BitBlt 方法:通过 GDI 的位图块传输(BitBlt)实现窗口…...

服务器防文件上传手写waf
一、waf的目录结构,根据自己目录情况进行修改 二、创建文件夹以及文件 sudo mkdir -p /www/server/waf-monitor sudo mkdir -p /www/server/waf-monitor/quarantine #创建文件夹 chmod 755 /www/server/waf-monitor #赋权cd /www/server/waf-monitor/touch waf-m…...
大模型为什么学新忘旧(大模型为什么会有灾难性遗忘)?
字数:2500字 一、前言:当学霸变成“金鱼” 假设你班上有个学霸,数学考满分,英语拿第一,物理称霸全校。某天,他突然宣布:“我要全面发展!从今天起学打篮球!” 一周后&am…...

计算机的基本组成与性能
1. 冯诺依曼体系结构:计算机组成的金字塔 1.1. 计算机的基本硬件组成 1.CPU - 中央处理器(Central Processing Unit)。 2.内存(Memory)。 3.主板(Motherboard)。主板的芯片组(Ch…...

linux下编写shell脚本一键编译源码
0 前言 进行linux应用层编程时,经常会使用重复的命令对源码进行编译,然后把编译生成的可执行文件拷贝到工作目录,操作非常繁琐且容易出错。本文编写一个简单的shell脚本一键编译源码。 1 linux下编写shell脚本一键编译源码 shell脚本如下&…...

【深度学习】#12 计算机视觉
主要参考学习资料: 《动手学深度学习》阿斯顿张 等 著 【动手学深度学习 PyTorch版】哔哩哔哩跟李沐学AI 目录 目标检测锚框交并比(IoU)锚框标注真实边界框分配偏移量计算损失函数 非极大值抑制预测 多尺度目标检测单发多框检测(S…...

Baklib赋能企业知识资产AI化升级
AI驱动知识管理革新 在数字化转型浪潮中,企业知识管理的范式正经历AI技术的深度重构。传统知识库受限于静态存储与人工维护,而Baklib通过构建知识中台架构,将多模态数据处理与语义理解引擎深度融合,实现知识资产的动态聚合与智能…...

【C++】模板上(泛型编程) —— 函数模板与类模板
文章目录 一、啥是泛型编程二、函数模板2.1、函数模板的概念2.2、函数模板的格式2.3、函数模板的原理2.4、函数模板的实例化2.4.1、隐式实例化:让编译器根据实参推演模板参数的实际类型2.4.2、显示实例化:在函数名后的<>中指定模板参数的实际类型 …...
软件架构之--论微服务的开发方法1
论微服务的开发方法1 摘要 2023年 2月,本人所在集团公司承接了长三角地区某省渔船图纸电子化审查系统项目开发,该项目旨在为长三角地区渔船建造设计院、以及渔船图纸审查机构提供一个便捷的渔船图纸电子化审查服务平台。在此项目中,我作为项目组成员参与项目的建设工作,并…...

【大模型系列】logprobs(对数概率)参数
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

C语言内存函数与数据在内存中的存储
一、c语言内存函数 1、memcpy函数是一个标准库函数,用于内存复制。功能上是用来将一块内存中的内容复制到另一块内存中。用户需要提供目标地址、源地址以及要复制的字节数。例如结构体之间的复制。 memcpy函数的原型是:void* memcpy(void* …...
代码案例分析
以下是一个使用线性回归进行简单房价预测的机器学习代码案例分析: 代码示例 import numpy as np import matplotlib.pyplot as plt from sklearn.linear_model import LinearRegression from sklearn.model_selection import train_test_split # 生成一些示例数据…...

通过MCP让LLM调用系统接口
场景 MCP的出现大大丰富了LLM的功能,对于存量系统,我们希望能让模型调用已有的接口,以最小的成本让AI能够获取系统内部数据。因此我们开发了一个名为http-api-call的MCP Server,来支持模型到内部API的调用 实现方案 使用用标准…...
如何利用Redis实现延迟队列?
延迟队列概念解析 延迟队列(Delay Queue)是一种特殊的消息队列,核心特性是允许消息在指定的延迟时间后被消费者处理,而非立即消费。它解决了传统队列(FIFO)无法处理“定时任务”或“超时任务”的问题&…...