AtCoder Beginner Contest 302(A-D)

news2025/1/4 20:16:50

TOYOTA MOTOR CORPORATION Programming Contest 2023#2 (AtCoder Beginner Contest 302)
Contest Duration: 2023-05-20(Sat) 20:00 - 2023-05-20(Sat) 21:40 (local time) (100 minutes)
暴搜场,1个小时出了4道,以为很有机会,结果E交了十发没过
记得赛后补题

A Attack 2 sec 1024 MB

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define fer(i,a,b) for(int i=a;i<b;i++)
#define mem(x, y) memset(x, y, sizeof(x))
#define cf int T;cin>>T;while(T--)
const int N1=1e6+10,N2=1e14,mod=1e9+7;
const int INF=0x3f3f3f3f;
signed main(){
	int a,b;cin>>a>>b;
	int res=a/b;
	if(a%b!=0)res++;
	cout<<res;
	return 0;
}

B Find snuke 2 sec 1024 MB

在这里插入图片描述
dfs找snuke,一开始题意理解错了,以为可以八个方向找,后来发现每次找只能固定一个方向
正解

char s[101][101];
bool f=0;
int dx[8]={0,0,-1,1,-1,-1,1,1};
int dy[8]={1,-1,0,0,-1,1,-1,1};
int n,m;
char target[5]={'s','n','u','k','e'};
int res[5][2];
void dfs(int i,int j,int t,int t1){
	if(t==5){
		f=1;return;
	}
	if(t1==-1){
		fer(k,0,8){
		if(!f&&i+dx[k]>=0&&i+dx[k]<n&&j+dy[k]>=0&&j+dy[k]<m){
			if(s[i+dx[k]][j+dy[k]]==target[t]){
				res[t][0]=i+dx[k];
				res[t][1]=j+dy[k];
				dfs(i+dx[k],j+dy[k],t+1,k);
			}
		}
		}
	}else{
		if(!f&&i+dx[t1]>=0&&i+dx[t1]<n&&j+dy[t1]>=0&&j+dy[t1]<m){
			if(s[i+dx[t1]][j+dy[t1]]==target[t]){
				res[t][0]=i+dx[t1];
				res[t][1]=j+dy[t1];
				dfs(i+dx[t1],j+dy[t1],t+1,t1);
			}
	}
}
}
signed main(){
	cin>>n>>m;
	fer(i,0,n){
		cin>>s[i];
	} 
	fer(i,0,n){
		fer(j,0,m){
			if(s[i][j]=='s'&&!f){
				res[0][0]=i;res[0][1]=j;
				dfs(i,j,1,-1);
			}
			
		}
	}
	fer(i,0,5){
		cout<<res[i][0]+1<<" "<<res[i][1]+1<<endl;
	}
	return 0;
}

题意理解错的解
差别只在这个是每次都找8个方向,正解只在第一次确定八个方向中的一个

char s[101][101];
bool f=0;
int dx[8]={0,0,-1,1,-1,-1,1,1};
int dy[8]={1,-1,0,0,-1,1,-1,1};
int n,m;
char target[5]={'s','n','u','k','e'};
int res[5][2];
void dfs(int i,int j,int t){
	if(t==5){
		f=1;return;
	}
	fer(k,0,8){
		if(!f&&i+dx[k]>=0&&i+dx[k]<n&&j+dy[k]>=0&&j+dy[k]<m){
			if(s[i+dx[k]][j+dy[k]]==target[t]){
				res[t][0]=i+dx[k];
				res[t][1]=j+dy[k];
				dfs(i+dx[k],j+dy[k],t+1);
			}
		}
	}
}
signed main(){
	cin>>n>>m;
	fer(i,0,n){
		cin>>s[i];
	} 
	fer(i,0,n){
		fer(j,0,m){
			if(!f&&s[i][j]==target[0]){
				res[0][0]=i;res[0][1]=j;
				dfs(i,j,1);
			}
		}
	}
	fer(i,0,5){
		cout<<res[i][0]+1<<" "<<res[i][1]+1<<endl;
	}
	return 0;
}

C Almost Equal 2 sec 1024 MB

在这里插入图片描述
在这里插入图片描述
开始想的是排序,后来发现不对,有点像数电的逻辑相邻,n只有8,全排列暴搜。可以直接用next_permutation

string s[8];
int n,m;
bool f=0;
bool use[8];
string res[8];
void dfs(int t){
	if(t==n){//全排列完毕,看能否组成目标 
	 	bool flag=1;
		fer(i,1,n){
			int cnt=0;
			fer(j,0,m){
				if(res[i][j]==res[i-1][j])continue;
				else{
					cnt++;
					if(cnt>=2){
						flag=0;break;
					}
				}
			}
			if(!flag)break;
		}
		if(flag)f=1;
//		fer(i,0,n){
//			cout<<s[i]<<endl;
//		}
//		cout<<endl;
	}
	fer(i,0,n){
		if(use[i]==0){
			use[i]=1;
			res[t]=s[i];
			dfs(t+1);
			use[i]=0;
		}
	}
}
signed main(){
	cin>>n>>m;
	fer(i,0,n)cin>>s[i];
	fer(i,0,n){
		if(!f){
			use[i]=1;
			res[0]=s[i];
			dfs(1);
			use[i]=0;
		}
	}
	if(f)cout<<"Yes"<<endl;
	else cout<<"No"<<endl;
	return 0;
}

dfs
在这里插入图片描述

D Impartial Gift 2 sec 1024 MB

在这里插入图片描述
排序,双指针
二分也可以

	signed main(){
	int n,m,d;cin>>n>>m>>d;
	fer(i,0,n)cin>>a[i];
	fer(i,0,m)cin>>b[i];
	sort(a,a+n);
	sort(b,b+m);
	int resa=-1,resb=-1;
	int i=n-1,j=m-1;
	while(i>=0&&j>=0){
		if(abs(a[i]-b[j])<=d){
			resa=a[i];resb=b[j];break;
		}else{
			if(a[i]>b[j])i--;
			else j--;
		}
	}
	if(resa==-1)cout<<-1<<endl;
	else cout<<resa+resb<<endl;
	return 0;
}

E Isolation

在这里插入图片描述
在这里插入图片描述
这道题大吐特吐,集合TLE了26个,vectorTLE4个,把endl改\n以后TLE了2个,最后也没出来,删邻边没想出好办法。看题解!!

TLE2个测试点的代码

	int n,q;
	scanf("%lld%lld",&n,&q);
	vector<int> v[n+1];
	int cnt=n,op,a,b;
	while(q--){
		scanf("%lld",&op);
		//cin>>op;
		if(op==1){
			scanf("%lld%lld",&a,&b);
			//cin>>a>>b;
			if(v[a].size()==0)cnt--;
			if(v[b].size()==0)cnt--;
			v[a].pb(b);
			v[b].pb(a);
			printf("%lld\n",cnt);
			//cout<<cnt<<"\n";
		}else{
			//cin>>a;
			scanf("%lld",&a);
			if(v[a].size()!=0)cnt++;
			vector<int>::iterator it;
			fer(i,0,v[a].size()){
				b=v[a][i];
    			it=find(v[b].begin(),v[b].end(),a);
    			v[b].erase(it);
    			if(v[b].size()==0)cnt++;
			}
			v[a].clear();
			printf("%lld\n",cnt);
			//cout<<cnt<<"\n";
		}
	}

E就卡了后面三道压根没看

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

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

相关文章

栈和队列OJ题:LeetCode--232.用栈实现队列

朋友们、伙计们&#xff0c;我们又见面了&#xff0c;今天给大家带来的是LeetCode--232.用栈实现队列 数 据 结 构 专 栏&#xff1a;数据结构 个 人 主 页 &#xff1a;stackY、 LeetCode 专 栏 &#xff1a;LeetCode刷题训练营 LeetCode--232.用栈实现队列&#xff…

使用 compose 封装一个通用的关于页面库

前言 现在很多 APP 都会有一个关于页面&#xff0c;用于放置一些必要的信息&#xff0c;例如&#xff1a;版本号、版权信息等。有时也会用于展示设置、帮助、反馈等功能的入口。 通常&#xff0c;我们都会自己挨个创建不同的 item &#xff0c;略显繁琐。 所以我就在想&…

ad18学习笔记一

如何自学altium designer如何自学altium designer&#xff1f; - 知乎如何自学altium designer 这里面有ad官方推荐的b站的视频&#xff1a;可以直接去b站关注ad官方账号 AltiumChina&#xff0c;它本身就发布了很多实用教程。 在知乎的这个界面也有Altium Designer Ver18_官…

万字长文,为你送上全网最全Flutter学习资料!

话不多说直接上目录&#xff0c;干货较多内容很长&#xff0c;建议先收藏供以后慢慢查阅。 目录 文章视频组件导航模板插件框架实验性游戏开源App实用工具社区书籍福利 文章 介绍 Google IO 2018 [1.1K&#x1f44f;] - 构建美观&#xff0c;灵活的用户界面。Presentation …

Stm32待机模式的进入与唤醒

1.基础介绍 1-1&#xff1a;单片机的“低功耗模式”&#xff0c;像是手机的待机模式&#xff0c;不同于正常运行模式&#xff0c;处于一种省电省资源的状态 1-2&#xff1a;在运行情况下&#xff0c;HCLK为cpu提供时钟&#xff0c;cortex-m3内核执行程序的代码&#xff0c;如…

CleanMyMac X2023Mac上下载最多的第三个实用程序

CleanMyMac X是一款广为人知的Mac优化应用程序&#xff0c;目前是Mac上下载最多的第三个实用程序&#xff0c;并获得苹果官方认证。为了满足用户更好体验Mac和新版系统&#xff0c;它们带来了新功能。这新功能可以帮助用户更好的监控Mac的健康状况&#xff0c;让用户畅享Mac新系…

base编码

https://www.qqxiuzi.cn/bianma/base64.htm 一眼就解密 一看就晓得是base64&#xff0c;问就是做多了&#xff08;base64大小写加数字和&#xff09; base编码概念 此博客列举的比较多&#xff0c;我信 https://blog.csdn.net/qq_53105813/article/details/127626450 简单聊几个…

少儿编程 中国电子学会图形化编程等级考试Scratch编程三级真题解析(选择题)2023年3月

2023年3月scratch编程等级考试三级真题 选择题(共25题,每题2分,共50分) 1、计算“2+4+8+……+128”,用变量n表示每项,根据变化规律,变量n的赋值用下列哪个最合适 A、 B、 C、 D、 答案:D 考点分析:考查数学逻辑推理能力,从给定的算式中可以看出后一项都是前一…

redis 数据库概述

一 概述 redis是一种nosql数据库,他的数据是保存在内存中&#xff0c;同时redis可以定时把内存数据同步到磁盘&#xff0c;即可以将数据持久化&#xff0c;并且他比memcached支持更多的数据结构(string,list列表[队列和栈],set[集合],sorted set[有序集合],hash(hash表))。相关…

基于springboot篮球竞赛预约平台

开发技术与环境配置 以Java语言为开发工具&#xff0c;利用了当前先进的springboot框架&#xff0c;以MyEclipse10为系统开发工具&#xff0c;MySQL为后台数据库&#xff0c;开发的一个篮球竞赛预约平台。 SpringBoot框架 SpringBoot是一个全新开源的轻量级框架。基于Spring…

Callback CBFS .NET 2022所有产品打包Crack

Callback CBFS .NET 所有产品打包 Callback Technologies CBFS Storage 2022 .NET Edition v22.0.8517 Callback Technologies CBFS Filter 2022 .NET Edition v22.0.8485 Callback Technologies CBFS Disk 2022 .NET Edition v22.0.8464 Callback Technologies CBFS Connect …

UART-STM32

UART-STM32 通信的目的:将一个设备的数据传送到另一个设备,扩展硬件系统 通信协议:制定通信的规则,通信双方按照协议规则进行数据收发 第一步,开启时钟,把需要用的USART和GPIO的时钟打开 第二步,GPIO初始化,把TX配置成复用输出,RX配置成输入 第三步,配置USART,直接使…

Kanzi Studio介绍与安装注意

文章目录 Kanzi介绍部署 Kanzi 应用程序到 Windows Kanzi介绍 Kanzi UI Solution是一个完整的UI解决方案&#xff0c;为嵌入式的UI的设计、开发和部署提供了一套完善的开发平台。它成功解决了实现和众多图形化用户界面分化的问题&#xff0c;使得用户界面的设计者和编程者可以…

vue的搭建以及命令

0.0 课程介绍 Vue介绍 【了解】 Vue项目的搭建 【掌握】 项目目录详解【掌握】 Vue组件化【掌握】 Vue的表达式 【重点】 Vue的指令【重点】 1.0 什么是Vue?【了解】 Vue是一个构建用户界面&#xff08;UI&#xff09;的JS库。 1.1Vue的特点 小 20k 【大概11000多行】…

HTTPS加密流程详解

文章目录 HTTPS与HTTP的关系HTTPS基本工作过程对称密钥非对称密钥中间人攻击证书 HTTPS与HTTP的关系 HTTPS协议基于HTTP&#xff0c;只是比HTTP多了一个加密层&#xff0c;为什么要加密呢&#xff1f;因为网络传输的过程中&#xff0c;明文传输的数据都有可能被劫持篡改&#…

系统分析师(一)软考简介

目录 1.证书简介2.考试简介3.考试报名4.各地考试机构5.考试要求6.考试教程用书 考试时间&#xff1a; 每年5月的最后一个周六 1.证书简介 ​ 软考全称是计算机技术与软件专业技术资格&#xff08;水平&#xff09;考试&#xff0c;是由国家人力资源和社会保障部、工业和信息化部…

【图】最小生成树

最小生成树&#xff1a;构造连通网的最小代价生成树。 最小生成树有两种算法&#xff1a;普利姆算法、克鲁斯卡尔算法。 普利姆&#xff08;Prim&#xff09;算法 加点&#xff0c;选择相邻点中边权最小的 需要两个一维数组&#xff0c;一个存权值&#xff0c;另一个存起始点…

MySQL 索引篇

什么是索引&#xff0c;索引就相当于一本书的目录。通过索引可以快速查找到对应的数据。 索引常见面试题&#xff1a; 1. 索引的分类&#xff1a; 按数据结构分类&#xff1a; 按物理存储分类&#xff1a;一般分为聚簇索引&#xff08;主键索引&#xff09;&#xff0c;二级…

【Java EE 初阶】文件操作

目录 1.什么是文件&#xff1f; 1.在cmd中查看指定目录的树形结构语法 2.文件路径 从当前目录开始找到目标程序&#xff08;一个点&#xff09; 返回到上一级目录&#xff0c;再找目标程序&#xff08;两个点&#xff09; 2.Java中文件操作 1.File概述 1.属性 2. 构造…

CENTO OS上的网络安全工具(二十二)Spark HA swarm容器化集群部署

在Hadoop集群swarm部署的基础上&#xff0c;我们更进一步&#xff0c;把Spark也拉进来。相对来说&#xff0c;在Hadoop搞定的情况下&#xff0c;Spark就简单多了。 一、下载Spark 之所以把这件事还要拿出来讲……当然是因为掉过坑。我安装的时候&#xff0c;hadoop是3.3.5&a…