AtCoder ABC346 A-E题解

news2024/11/16 4:26:47

比赛链接:ABC346

Problem A:

签到题。

#include <bits/stdc++.h>
using namespace std;
const int maxn=105;
int A[105],B[105];
int main(){
	int N;
	cin>>N;
	for(int i=1;i<=N;i++)
		cin>>A[i];
	for(int i=1;i<N;i++){
		B[i]=A[i+1]*A[i];
		cout<<B[i]<<endl;
	}
	return 0;
}

Problem B:

这题并不需要什么高级的玩意,只用把S复制几遍,然后暴力判断即可。(思路源于tourist的代码)

#include <bits/stdc++.h>
using namespace std;
int main(){
	string S="wbwbwwbwbwbw";
	while(S.size()<10000)
		S+=S;
	int W,B;
	cin>>W>>B;
	for(int i=0;i<((int)S.size()-W-B);i++){
		string t=S.substr(i,W+B);
		if(count(t.begin(),t.end(),'w')==W){
			cout<<"Yes"<<endl;
			return 0;
		}
	}
	//cout<<"No"<<endl;
	return 0;
}

Problem C:

把A扔到一个set里,然后遍历set即可。时间复杂度\Theta (N)

//long long
#include <bits/stdc++.h>
using namespace std;
const int maxn=200005;
int A[maxn];
set<int> st;
int main(){
	long long N,K;
	cin>>N>>K;
	for(int i=1;i<=N;i++){
		cin>>A[i];
		st.insert(A[i]);
	}
	int ans=(1+K)*K/2;
	for(int x:st){
		if(1<=x && x<=K)
			ans-=x;
	}
	cout<<ans<<endl;
	return 0;
}

Problem D:

Why DP?????????????????????????????????????????????????????

我们令dp_{i,j,k}表示当前的状态。i是第i个字符,j是当前字符选不选,k是是否有连续。

然后我们分类讨论这个字符和上一个字符是否相同即可。

//long long
#include <bits/stdc++.h>
using namespace std;
const int maxn=200005;
int C[maxn],dp[maxn][2][2];
int main(){
	int N;
	string S;
	cin>>N>>S;
	memset(dp,0x3f3f3f3f,sizeof(dp));
	for(int i=0;i<N;i++)
		cin>>C[i];
	dp[0][0][0]=0;
	dp[0][1][0]=C[0];
	for(int i=1;i<N;i++){
		if(S[i]==S[i-1]){
			dp[i][1][0]=min(dp[i][1][0],dp[i-1][0][0]+C[i]);
			dp[i][0][0]=min(dp[i][0][0],dp[i-1][1][0]);
			dp[i][0][1]=min(dp[i][0][1],min(dp[i-1][0][0],dp[i-1][1][1]));
			dp[i][1][1]=min(dp[i][1][1],min(dp[i-1][0][1],dp[i-1][1][0])+C[i]);
		}
		else{
			dp[i][1][0]=min(dp[i][1][0],dp[i-1][1][0]+C[i]);
			dp[i][0][0]=min(dp[i][0][0],dp[i-1][0][0]);
			dp[i][0][1]=min(dp[i][0][1],min(dp[i-1][1][0],dp[i-1][0][1]));
			dp[i][1][1]=min(dp[i][1][1],min(dp[i-1][1][1],dp[i-1][0][0])+C[i]);
		}
	}
	cout<<min(dp[N-1][1][1],dp[N-1][0][1])<<endl;
	return 0;
}

Problem E:

直接模拟必然超时,考虑倒序(你前面最多少次都没用,会被覆盖)。然后,比方说,第x行染成1,后续进行了y次列的染色,所以这一行有x-y个颜色为1的格子。把这些记录下来即可。

int row,col;
long long H,W,M;
long long res[maxn];
map<pair<long long,long long>,bool> mp;
vector<pair<long long,long long>> ans;
struct cell{
	long long t;
	long long a;
	long long x;
}grid[maxn];
void work(long long t,long long a,long long x){
	pair<long long,long long> op={t,a};
	if(mp.count(op))
		return;
	mp[op]=true;
	if(t==1){
		res[x]+=W-row;
		++col;
	}
	else{
		res[x]+=H-col;
		++row;
	}	
}
int main(){
	cin>>H>>W>>M;
	for(int i=1;i<=M;i++)
		cin>>grid[i].t>>grid[i].a>>grid[i].x;
	for(int i=M;i>0;--i)
		work(grid[i].t,grid[i].a,grid[i].x);
	for(int i=1;i<=H;i++)
		work(1,i,0);
	for(int i=0;i<=200000;i++){
		if(res[i])
			ans.push_back(make_pair(i,res[i]));
	}
	cout<<ans.size()<<endl;
	for(auto x:ans)
		cout<<x.first<<' '<<x.second<<endl;
}

以上就是本期的全部内容了,我们下期再见!

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

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

相关文章

【Godot4.2】像素直线画法及点求取函数

概述 基于CanvasItem提供的绘图函数进行线段绘制只需要直接调用draw_line函数就可以了。 但是对于可以保存和赋值节点直接使用的纹理图片&#xff0c;却需要依靠Image类。而Image类没有直接提供基于像素的绘图函数。只能依靠set_pixel或set_pixelv进行逐个像素的填色。 所以…

Linux 的 app :一般到哪里下载 ?(**)

利用 appimagetool 工具对开发好的项目进行打包 &#xff08;***带笔记*&#xff09; https://blog.csdn.net/ken2232/article/details/131313613 1. 首选&#xff0c;直接通过 OS发行版的官网仓库&#xff1a;简单、方便&#xff1b;可能相对最可靠。 如&#xff1a; sudo a…

matlab基于Simulink的模糊逻辑控制应用

一、原理 模糊逻辑指模仿人脑的不确定性概念判断、推理思维方式&#xff0c;对于模型未知或不能确定的描述系统&#xff0c;以及强非线性、大滞后的控制对象&#xff0c;应用模糊集合和模糊规则进行推理&#xff0c;表达过渡性界限或定性知识经验&#xff0c;模拟人脑方式&…

基于YOLOv8深度学习的橙子病害智能诊断与防治系统【python源码+Pyqt5界面+数据集+训练代码】深度学习实战、目标分类

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

算法:bfs(深度优先搜索)

// dfs习题&#xff1a; // 输入9行&#xff0c;0代表未知 // 输出9行即最终结果 #include <stdio.h> #include <stdlib.h> int main() {int table[9][9];//输入数据for (int i 0; i < 9; i) {for (int j 0; j < 9; j) {scanf("%d", &table[…

js工具方法记录

校验数字是否有效的11位手机号 function isValidPhoneNum(value: string) {return /^[1][3,4,5,6,7,8,9][0-9]{9}$/.test(value) }手机号中间4位掩码 function maskPhoneNum(phone: string, space false) {if (!phone) {return }const reg /(\d{3})\d{4}(\d{4})/return pho…

【测试开发学习历程】MySQL分组查询与子查询 + MySQL表的联结操作

目录 1 MySQL分组查询与子查询 1.1 数据分组查询 1.2 过滤分组 1.3 分组结果排序 1.4 select语句中子句的执行顺序 1.5 子查询 2 MySQL表的联结操作 2.1 关系表 2.2 表联结 2.3 笛卡尔积 2.4 内部联结 2.5 外联结 2.6 自联结 2.7 组合查询 1 MySQL分组查询与子查询…

LangChain-Chatchat知识库对话

前言 上次我们完成了Chatchat的本地部署&#xff0c;使用了LLM对话的功能。这次我们尝试一下其他的功能&#xff0c;之前总是有报错没有跑通&#xff0c;这次处理了几个问题之后才跑通了知识库对话和文件对话。 知识库对话 原理: 首先我们看这个图可以明白&#xff0c;知识库…

Redis学习二--常见问题及处理

基本概念 Redis基本概念数据结构 机制 持久化机制&#xff1a; RDB(内存快照)&#xff1a;某一时刻的内存快照以二进制的方式写入磁盘&#xff0c;可以手动触发和自动触发。 优点&#xff1a;生成文件小&#xff0c;恢复速度快&#xff0c;适用于灾难恢复。 缺点&#xff1a…

03-SparkSQL入门

0 Shark Spark 的一个组件&#xff0c;用于大规模数据分析的 SQL 查询引擎。Shark 提供了一种基于 SQL 的交互式查询方式&#xff0c;可以让用户轻松地对大规模数据集进行查询和分析。Shark 基于 Hive 项目&#xff0c;使用 Hive 的元数据存储和查询语法&#xff0c;并基于Hiv…

MySQL5.6.11安装步骤(Windows7 64位)

MySQL5.6.11安装步骤&#xff08;Windows7 64位&#xff09; 1. 下载MySQL Community Server 5.6.21&#xff0c;注意选择系统类型&#xff08;32位/64位&#xff09; 2. 解压MySQL压缩包 将以下载的MySQL压缩包解压到自定义目录下。 3. 添加环境变量 变量名&#xff1a;MYS…

【项目设计】基于MVC的负载均衡式的在线OJ

项目代码&#xff08;可直接下载运行&#xff09; 一、项目的相关背景 学习编程的小伙伴&#xff0c;大家对力扣、牛客或其他在线编程的网站一定都不陌生&#xff0c;这些编程网站除了提供了在线编程&#xff0c;还有其他的一些功能。我们这个项目只是做出能够在线编程的功能。…

“低代码+平台”:驱动企业数字化转型与创新的新引擎

“低代码平台”作为一种新兴的软件开发范式&#xff0c;正逐渐成为企业快速响应市场变化、优化业务流程、提升数字化水平的重要手段。它的价值在于&#xff0c;将传统软件开发的复杂性大大降低&#xff0c;赋予了非技术人员或轻量级开发者快速构建应用的能力&#xff0c;并能灵…

可视化驯龙高手:Portainer——轻松驾驭Docker的图形化管理利器

在Docker容器技术的海洋中&#xff0c;Portainer如同一艘满载智能导航系统的旗舰&#xff0c;为我们提供了直观且易用的图形化管理界面&#xff0c;让繁杂的容器管理和运维工作变得轻松愉悦。本文将带你了解Portainer的基本功能&#xff0c;掌握其安装方法&#xff0c;并体验其…

摘录笔记——2024年3月22日

目录 一、背景 1.1 新人的选择困局 1.2 高人才密度环境下普通员工的成长效率困局 1.3 业务发展和个人成长的二元对立困局 1.4 中年打工人低费效比引发的职场生涯终结困局 二、人的本质 2.1 人的本质的定义 2.2 由“人的本质”引出的几个关键过程 2.2.1 认知指引实践&a…

【前端寻宝之路】学习和总结HTML表格的实现和合并

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法|MySQL| ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” #mermaid-svg-IWDj0gWiFt6IMq3x {font-family:"trebuchet ms",verdana,arial,sans-serif;f…

啥是反射???

在Java编程中&#xff0c;反射&#xff08;Reflection&#xff09;是一种强大的工具&#xff0c;它允许程序在运行时检查类、接口、字段和方法的信息&#xff0c;并且可以动态地创建和操作对象。 一、反射的基本概念 反射是Java语言的一个特性&#xff0c;它允许程序在运行时对…

QML ShapePath绘制虚线

一.qml PathLine介绍 在 QML&#xff08;Qt Modeling Language&#xff09;中&#xff0c;PathLine 是 Path 元素的一个子类型&#xff0c;用于创建两点之间的直线段。Path 类型用于描述一个二维路径&#xff0c;可以用来绘制形状、曲线和直线。PathLine 是所有路径曲线中最简单…

从0写一个问卷调查APP的第13天-1

1.今日任务 我也只是一个大学生&#xff0c;有什么思路不对的地方给我指出来哟! 分析&#xff1a;上次我们实现了任务调查的插入。但是我们插入的问卷调查只有它的标题&#xff0c;也就是这个问卷调查是什么我们告诉数据库了&#xff0c;但是现在我们还没有给它添加任何问题&…

域控操作十三:域用户登陆前显示标题以及文本

域控用户在登录前会先显示这个&#xff0c;才能输入密码登录