Codeforces 962 div3 A-F

A

题目分析

签到

 C++代码

#include<iostream>
using namespace std;
int main(){int t;cin>>t;while(t--){int n;cin>>n;cout<<n/4+n%4/2<<endl;}
}

B

题目分析

将n*n的方格分成若干个k*k的方格,每个k*k的方格中所有的数都相同

遍历每个k*k的第一个数即可,然后存入另一个(n/k)*(n/k)的数组中

 C++代码

#include<iostream>
using namespace std;
const int N=1010;
char g[N][N];
int n,k;
void solve(){cin>>n>>k;for(int i=1;i<=n;i++)scanf("%s",g[i]+1);char t[n/k+1][n/k+1];for(int i=1,cnt=1;i<=n;i+=k,cnt++){for(int j=1,cnt1=1;j<=n;j+=k,cnt1++){t[cnt][cnt1]=g[i][j];}}for(int i=1;i<=n/k;i++){for(int j=1;j<=n/k;j++)cout<<t[i][j];cout<<endl;}
}
int main(){int t;cin>>t;while(t--){solve();}return 0;
}

C

题目分析

设置两个数组预处理字符串a和b的字母出现次数的前缀和

sa[N][26]:sa[i][j]表示字符串a中第1~i个字符中字母(j+'a')出现的个数

sb[N][26]:sb[i][j]表示字符串b中第1~i个字符中字母(j+'a')出现的个数

用递推的方式更新sa和sb数组

之后处理询问就计算[l,r]中字符串a和字符串b出现的所有字母的个数之差,把它们都加起来,然后除以2就是答案了

 C++代码

#include<iostream>
using namespace std;
const int N=200010;
char a[N],b[N];
int n,q;
void solve(){scanf("%d%d",&n,&q);scanf("%s%s",a+1,b+1);int sa[n+5][26]={0},sb[n+5][26]={0};for(int i=1;i<=n;i++){sa[i][a[i]-'a']++;sb[i][b[i]-'a']++;//用i-1时的状态更新i的状态for(int j=0;j<26;j++){sa[i][j]+=sa[i-1][j];sb[i][j]+=sb[i-1][j];}}while(q--){int l,r,ans=0;scanf("%d%d",&l,&r);for(int i=0;i<26;i++){//a的[l,r]中字母i+'a'的个数和b的[l,r]中字母i+'a'的个数之差ans+=abs((sa[r][i]-sa[l-1][i])-(sb[r][i]-sb[l-1][i]));}printf("%d\n",ans/2);}
}
int main(){int t;scanf("%d",&t);while(t--){solve(); }return 0;
}

D

题目分析

ab+ac+bc≤n,a+b+c≤x(a,b,c都大于等于1)

枚举三个数肯定是不可取的,那我们可以只枚举a和b两个数,然后判断c有几种选法,然后加入到答案中去就行

ab+ac+bc≤n => ab<n     a+b+c≤x => a+b<x

ab+ac+bc≤n =>c≤(n-ab)/(a+b)

a+b+c≤x => c≤x-a-b

所以:c ≤ min ((n-ab)/(a+b) , x-a-b)

 C++代码

#include<iostream>
using namespace std;
typedef long long LL;
void solve(){int n,x;cin>>n>>x;LL ans=0;for(int a=1;a<min(n,x);a++)for(int b=1;a*b<n&&a+b<x;b++){//总方案数加上当前情况下c可选的方案数ans+=min((n-a*b)/(a+b),x-a-b);}cout<<ans<<endl;
}
int main(){int t;cin>>t;while(t--){solve();}return 0;
}

E

题目分析

任意区间包含多少个符合条件的区间的转换成符合条件的区间被多少个区间包含

假设区间[i,j]符合条件,则包含该区间的区间有i*(n-j+1)个

字符串只包含0和1,要找的区间0和1一样多,所以我们可以把0变成-1,转换成要找区间和为0的区间

所以我们枚举每个区间的右端点,但是暴力找左端点肯定不行,所以要挖掘点性质

设置一个前缀和数组sum,

如果sum[i]==sum[j],则区间[i+1,j]的区间和为0,对答案的贡献为(i+1)*(n-j+1)

如果sum[k]==sum[j],则区间[k+1,j]的区间和为0,对答案的贡献为(k+1)*(n-j+1)

加起来就是(i+1+k+1)*(n-j+1)

由此可见,我们从前往后枚举每一个右端点j,找到在此之前的前缀和等于sum[j]的数,i+1就可以是区间的左端点,然后就可以用map存储每个相同前缀和对应的左端点的和

 C++代码

#include<iostream>
#include<vector>
#include<map> 
using namespace std;
typedef long long LL;
const int N=200010,mod=1e9+7; 
void solve(){string s;cin>>s;LL n=s.size();s=' '+s;vector<int> a(n+5),sum(n+5);for(int i=1;i<=n;i++)a[i]=(s[i]=='0'?-1:1);//0变成-1,1还是1for(int i=1;i<=n;i++)sum[i]=sum[i-1]+a[i];map<int,LL> mp;mp[0]=1;LL ans=0;for(int i=1;i<=n;i++){ans+=mp[sum[i]]*(n-i+1)%mod;//以i为右端点的所有左端点的和为mp[sum[i]]mp[sum[i]]+=(i+1);}cout<<ans%mod<<"\n";
}
int main(){int t;cin>>t;while(t--){solve();}return 0;
}

F

题目分析

二分操作的数中最小的数

 C++代码

#include<iostream>
using namespace std;
typedef long long LL;
const int N=200010;
int a[N],b[N];
LL score[N],ans;
int n,k;
bool check(LL x){LL cnt=0,res=0,sumx=0;for(int i=1;i<=n;i++){LL t=(a[i]-x+b[i]-1)/b[i];//上取整,先把所有大于x的数都算上LL p=a[i]-t*b[i];//剩余的最大的数 if(t<0)continue;if(p&&p==x)sumx++;//剩余的最大的数为x,则x的个数加一 cnt+=t;//操作次数+t res+=min(score[i],t*a[i]-(t-1)*t/2*b[i]);}if(cnt<=k)ans=max(ans,min(k-cnt,sumx)*x+res);return cnt<=k;
}
void solve(){cin>>n>>k;for(int i=1;i<=n;i++)cin>>a[i];for(int i=1;i<=n;i++){cin>>b[i];LL t=a[i]/b[i];//score[i]表示靠第i个元素最多可以获得的分数 score[i]=a[i]%b[i]+t*a[i]-(t-1)*t*b[i]/2;}ans=0;//二分k次操作中获得的最少的一个分数 int l=0,r=1e18;while(l<r){LL mid=l+r>>1;if(check(mid))r=mid;else l=mid+1;}cout<<ans<<endl;
}
int main(){int t;cin>>t;while(t--){solve();}return 0;
}

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

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

相关文章

SwiftUI知识点(四)

NavigationStack import SwiftUIstruct NavigationStackBootcamp: View {let fruits ["Apple", "Orange", "Banana"]///路径数组State private var stackPath: [String] []var body: some View {NavigationStack(path: $stackPath) {VStack{B…

RocketMQ的Admin Tool工具

文档&#xff1a;https://github.com/apache/rocketmq/blob/develop/docs/cn/operation.md写的很全面&#xff0c;我写了一半就偷懒了&#xff0c;地址放这里。 命令大全&#xff1a;https://github.com/apache/rocketmq/blob/develop/docs/cn/operation.md 1. 删除讨厌的告警…

文献笔记|综述|A Survey of Large Language Models (前3章)

A Survey of Large Language Models 题目&#xff1a;大语言模型综述 作者&#xff1a;Wayne Xin Zhao, Kun Zhou, Junyi Li et al. 来源&#xff1a;arXiv 单位&#xff1a;中国人民大学高瓴人工智能学院、中国人民大学信息学院 关键词&#xff1a;Large Language Models; Eme…

AI之AI by Hand:AI by Hand(手动自定义AI算法的数学逻辑)的简介、使用方法、案例应用之详细攻略

AI之AI by Hand&#xff1a;AI by Hand(手动自定义AI算法的数学逻辑)的简介、使用方法、案例应用之详细攻略 目录 AI by Hand的简介 AI by Hand的使用方法 1、解读混合专家&#xff08;MoE&#xff09; 2、解读LSTM (Long Short-Term Memory) AI by Hand的案例应用 AI by …

学习大数据DAY25 Shell脚本的书写2与Shell工具的使用

目录 自定义函数 递归-自己调用自己 上机练习 12 Shell 工具 sort sed awk 上机练习 13 自定义函数 name(){ action; } function name { Action; } name 因为 shell 脚本是从上到下逐行运行&#xff0c;不会像其它语言一样先编译&#xff0c;所以函数必 须在调…

MyBatis-Plus自动生成代码

目录 前言一. 什么是 MyBatis-Plus1. Mybatis-Plus 的特点2. Mybatis-Plus 结构二. MyBatis-Plus 自动生成步骤1. 数据库准备2. 环境准备(1) 创建一个空的 Spring Boot 工程(2) 导入pom依赖(3) 编辑application.yml文件(4) 在启动类加入 @MapperScan 注解3. 配置代码4. 运行三.…

江科大/江协科技 STM32学习笔记P15

文章目录 TIM输出比较1、输出比较简介2、PWM简介3、输出比较通道&#xff08;高级&#xff09;4、输出比较通道&#xff08;通用&#xff09;5、输出比较模式6、PWM基本结构参数计算 7、舵机简介8、直流电机及驱动简介驱动芯片 TIM输出比较 1、输出比较简介 CNT计数器&#x…

VUE3——003、VUE 项目中的文件结构(index.html、main.ts、App.vue)

虽然是号称是小白初学&#xff0c;但本文只是对 VUE 小白&#xff0c;其它的基功还是有一丢丢的&#xff0c;不太懂的同学去看看一下详解&#xff0c;我这里记述的是自己的理解和观点。见谅&#xff01; index.html&#xff1a;入口文件&#xff08;以创建 vue3 项目的默认文件…

ElasticSearch(es)倒排索引

目录 一、ElasticSearch 二、倒排索引 1. 正向索引 2. 倒排索引 具体细节 1. 文档分析 2. 索引构建 3. 索引存储 4. 词条编码 5. 索引优化 6. 查询处理 示例 总结 3. 正向和倒排 三、总结 倒排索引的基本概念 为什么倒排索引快 一、ElasticSearch Elasticsear…

Vue 3 中使用 InMap 绘制热力图

本文由ScriptEcho平台提供技术支持 项目地址&#xff1a;传送门 Vue 3 中使用 InMap 绘制热力图 应用场景介绍 InMap 是一款强大的地图组件库&#xff0c;它提供了一系列丰富的可视化功能&#xff0c;包括热力图。热力图可以将数据点在地图上以颜色编码的方式可视化&#x…

论文阅读_字节的语音生成模型_Seed-TTS

英文名称: Seed-TTS: A Family of High-Quality Versatile Speech Generation Models 中文名称: Seed-TTS&#xff1a;高质量多功能语音生成模型系列 链接: http://arxiv.org/abs/2406.02430v1 代码: https://github.com/BytedanceSpeech/seed-tts-eval (评测工具) 演示网站&am…

找出所有点到一个点的距离的最小值

这个题的看一眼有点像树形dp&#xff0c;但是要怎么去优化我们转移方程呢 这是为什么呢&#xff0c;我们的树形dp很难考虑来之前的答案&#xff0c;那么d[y] 怎么办&#xff0c;我们可以先以1为根计算出以1为根的答案 #define _CRT_SECURE_NO_WARNINGS #include<bits/stdc.…

js 计算小数精度问题 ,引入decimal.js库 解决

安装 npm install --save decimal.js 引入 import Decimal from "decimal.js" 使用 new Decimal function adddDecimals (...decimals) { let sum new Decimal(0) decimals.forEach(decimal > { sum sum.plus(decimal) }) return sum.toNumber() } const res …

【刷题汇总 -- 笨小猴、 主持人调度(一)、分割等和子集】

C日常刷题积累 今日刷题汇总 - day0251、笨小猴1.1、题目1.2、思路1.3、程序实现 2、主持人调度&#xff08;一&#xff09;2.1、题目2.2、思路2.3、程序实现 3、分割等和子集3.1、题目3.2、思路3.3、程序实现 -- 0/1背包问题 4、题目链接 今日刷题汇总 - day025 1、笨小猴 1…

【MIT 6.5840(6.824)学习笔记】Raft

1 脑裂 许多容错系统使用一个单主节点来决定主副本。 MapReduce&#xff1a;由单主节点控制计算复制。GFS&#xff1a;主备复制数据&#xff0c;并由单主节点确定主拷贝的位置。VMware FT&#xff1a;主虚机和备份虚机之间复制指令&#xff0c;需要单点的Test-and-Set服务确认…

【JavaEE】通过Linux部署Web项目到云服务器上

一.配置部署所需的环境. 1.1 什么是部署? 要想知道什么是部署, 就要先了解我们在日常开发的过程中所设计到的几种环境: 开发环境: 软件开发环境指的是开发人员在创建、测试和部署软件应用程序时所需的一系列硬件、软件、工具和流程的集合。它是为了支持软件开发过程而构建的…

[算法]归并排序(C语言实现)

一、归并排序的定义 归并排序&#xff08;Merge sort&#xff09;是建立在归并操作上的一种有效的排序算法。该算法是采用分治法&#xff08;Divide and Conquer&#xff09;的一个非常典型的应用。 二、归并排序的算法原理 归并排序的算法可以用递归法和非递归法来实现…

Git基本原理讲解、常见命令、Git版本回退、Git抛弃本地分支拉取仓库最新分支、如何将本地文件推送至github、.gitignore文件的使用

借此机会写篇博客汇总一下自己去公司实习之后遇到的一些常见关于Git的操作。 Git基本认识 Git把数据看作是对小型文件系统的一组快照&#xff0c;每次提交更新&#xff0c;或在Git中保存项目状态时&#xff0c;Git主要对当时的全部文件制作一个快照并保存这个快照的索引。同时…

【ROS 最简单教程 002/300】ROS 环境安装 (虚拟机版): Noetic

&#x1f497; 有遇到安装问题可以留言呀 ~ 当时踩了挺多坑&#xff0c;能帮忙解决的我会尽力 &#xff01; 1. 安装操作系统环境 Linux ❄️ VM / VirtualBox Ubuntu20.04 &#x1f449; 保姆级图文安装教程指路&#xff0c;有经验的话 可以用如下资源自行安装 ITEMREFERENCE…