Toyota Programming Contest 2023#4(AtCoder Beginner Contest 311)(A-G)

Contest Duration: 2023-07-22(Sat) 20:00 - 2023-07-22(Sat) 21:40 (local time) (100 minutes)

头文件和宏

#include<iostream>
#include<string>
#include<vector>
using namespace std;
#define int long long
#define fer(i,a,b) for(int i=a;i<b;i++)
#define cf int T;cin>>T;while(T--)
#define pb push_back
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);

以下只附主代码

A First ABC

从头开始,找出ABC三个字母都至少出现一次的最小长度

signed main(){IOS;int n;cin>>n;string s;cin>>s;bool fa=0,fb=0,fc=0;int cnt=0;fer(i,0,n){if(s[i]=='A')fa=1;else if(s[i]=='B')fb=1;else if(s[i]=='C')fc=1;if(fa&&fb&&fc){cnt=i;break;}}cout<<cnt+1;return 0;
}

B Vacation Together

找出n人均有空闲的最大天数

signed main(){IOS;int n,d;cin>>n>>d;bool f[d]={0};string s;fer(i,0,n){cin>>s;fer(j,0,d){if(s[j]=='x')f[j]=1;}}int cnt=0,mx=0;fer(i,0,d){if(f[i]==0){cnt++;mx=max(mx,cnt);}else cnt=0;}cout<<mx;return 0;
}

C Find it!

有向图,N个结点,N条边,一个结点只会指向另外一个结点,产生一条边。题目要求输出任意环。
这种方式形成的有向图一定有环,最小的环是M=2,最大的环是M=N,所以只要顺着找N+1次,必然会出现环,res里最后一个结点必然在环里。即使重复在一个环里循环也无妨,只需从后向前截取这个环作为结果。

const int N=2e5+5,mod=1e9+7;
int a[N];
signed main(){IOS;int n;cin>>n;fer(i,1,n+1)cin>>a[i];vector<int>res;res.clear();int j=1;res.pb(j);fer(i,0,n+1){res.pb(a[j]);j=a[j];}int k;for(int i=n-1;i>=0;i--){if(res[i]==res[n]){k=i;break;}}cout<<n-k<<endl;for(int i=k;i<n;i++){cout<<res[i]<<" ";}return 0;
}

D Grid Ice Floor

滑冰,如果玩过类似的4399小游戏会感到熟悉。
在冰面上只能朝指定方向滑行,直到遇到障碍物停下,中途不能改变方向。问最多能滑过多少块冰。问题在于:如何判定停止递归?不能只是单纯遇到走过的点就停止。比如下图中的红线是可以走的,但如果“遇到走过的点就停止”,那么就不会递归这条红线的情况,这是错误的。
请添加图片描述
因此我设置了两个布尔数组,f代表走过的点,用来计数;f2代表该点是否作为过停留的结点向四个方向递归,如果f2==1,那么我们不必重复去递归

int a[202][202];bool f[202][202],f2[202][202];
int cnt=0;
void solve(int x,int y,int op){//1上 2下 3左 4右 if(f[x][y]==0){cnt++;f[x][y]=1;}if(op==0&&f2[x][y]==0){f2[x][y]=1;if(a[x-1][y])solve(x-1,y,1);if(a[x+1][y])solve(x+1,y,2);if(a[x][y-1])solve(x,y-1,3);if(a[x][y+1])solve(x,y+1,4);return;}else if(op==1){if(a[x-1][y])solve(x-1,y,1);else solve(x,y,0);}else if(op==2){if(a[x+1][y])solve(x+1,y,2);else solve(x,y,0);}else if(op==3){if(a[x][y-1])solve(x,y-1,3);else solve(x,y,0);}else if(op==4){if(a[x][y+1])solve(x,y+1,4);else solve(x,y,0);}
}
signed main(){IOS;int n,m;cin>>n>>m;string s;fer(i,0,n){cin>>s;fer(j,0,m){if(s[j]=='.')a[i+1][j+1]=1;}}solve(2,2,0);cout<<cnt<<endl;
//	fer(i,1,n+1){
//		fer(j,1,m+1)cout<<f[i][j]<<" ";
//		cout<<endl;
//	}return 0;
}

下面是非递归的版本,用的是队列,这种方式开销较小

vector<int> dx = {1, 0, -1, 0};
vector<int> dy = {0, 1, 0, -1};
int main(){int N, M;cin >> N >> M;vector<string> S(N);for (int i = 0; i < N; i++){cin >> S[i];}vector<vector<bool>> used(N, vector<bool>(M, false));used[1][1] = true;vector<vector<bool>> used2(N, vector<bool>(M, false));used2[1][1] = true;queue<pair<int, int>> Q;Q.push(make_pair(1, 1));while (!Q.empty()){int x = Q.front().first;int y = Q.front().second;Q.pop();for (int i = 0; i < 4; i++){int x2 = x, y2 = y;while (S[x2 + dx[i]][y2 + dy[i]] == '.'){x2 += dx[i];y2 += dy[i];used2[x2][y2] = true;}if (!used[x2][y2]){used[x2][y2] = true;Q.push(make_pair(x2, y2));}}}int ans = 0;for (int i = 0; i < N; i++){for (int j = 0; j < M; j++){if (used2[i][j]){ans++;}}}cout << ans << endl;for (int i = 0; i < N; i++){for (int j = 0; j < M; j++){cout<<used2[i][j]<<" ";}cout<<endl;}return 0;
}

参考:Submission #43834581

E Defect-free Squares

问无洞正方形有多少个。动态规划
dp初始化为最大值3000+

  • 如果该点是洞,该点dp[i][j]=0;
  • 如果不是:
    • 如果是最底下一行和最右面一列,dp[i][i]=1
    • 如果不是:dp[i][i]=min(dp ,dp[i+1][j]+1,dp[i][j+1]+1,dp[i+1][j+1]+1),也就是取(自身、右面+1、下面+1、右下+1)中的最小值。

如果右面或者下面是洞,都影响自身构建无洞正方形

bool f[3001][3001];
int dp[3001][3001];
signed main(){IOS;int h,w,n;cin>>h>>w>>n;int a,b;fer(i,1,n+1){cin>>a>>b;f[a][b]=1;}fer(i,1,h+1){fer(j,1,w+1)dp[i][j]=3005;}int sum=0;for(int i=h;i>=1;i--){for(int j=w;j>=1;j--){if(i==h||j==w)dp[i][j]=1;if(i<h)dp[i][j]=min(dp[i][j],dp[i+1][j]+1);if(j<w)dp[i][j]=min(dp[i][j],dp[i][j+1]+1);if(i<h&&j<w)dp[i][j]=min(dp[i][j],dp[i+1][j+1]+1);if(f[i][j])dp[i][j]=0;sum+=dp[i][j];	}} cout<<sum<<endl;return 0;
}

参考:Submission #43837221

F Yet Another Grid Task

给一个网格,有黑块有白块。小明要把白块涂成黑块使得网格变beautiful,beautiful的定义如下:一个黑块的下面一块和右下角的一块也是黑块。问有多少种涂法。
动态规划,dp初始化为1,按列dp,对每列找到黑块出现的最早一次位置,在这位置之后的块的可能次数均为0(因为黑块之下必须是黑块,已经被定好了),在这位置之前的块,可能次数是自身的可能次数+下方块的可能次数,然后dp整体下移

const int N=2e5+1,mod=998244353;
signed main(){IOS;int n,m;cin>>n>>m;vector<string>s(n);fer(i,0,n)cin>>s[i];vector<int> dp(n+1,1);fer(i,0,m){int x=0;while(x<n&&s[x][i]=='.')x++;for(int j=x+1;j<=n;j++){dp[j]=0;}for(int j=n-1;j>=0;j--){dp[j]+=dp[j+1];dp[j]%=mod;}for(int j=n;j>0;j--){dp[j]=dp[j-1];dp[j]%=mod;}} cout<<dp[0];return 0;
}

参考:Submission #43851107

G One More Grid Task

在网格内拉一个矩形,求(矩形内和x矩形内最小值)的最大值
s存放该列数字的和,t存放该列数字的最小值,待想

signed main(){IOS;int n,m;cin>>n>>m;vector<vector<int> > a(n,vector<int>(m));fer(i,0,n){fer(j,0,m)cin>>a[i][j];}int ans=0;fer(u,0,n){vector<int>s(m),t(m,1e9);fer(d,u,n){fer(i,0,m){s[i]+=a[d][i];t[i]=min(a[d][i],t[i]);}vector<int> l(m,-1),r(m,m),stk;fer(i,0,m){while(!stk.empty()&&t[i]<t[stk.back()]){r[stk.back()]=i;stk.pop_back();}if(!stk.empty())l[i]=stk.back();stk.pb(i);}vector<int> pre(m+1);fer(i,0,m)pre[i+1]=pre[i]+s[i];fer(i,0,m)ans=max(ans,t[i]*(pre[r[i]]-pre[l[i]+1]));}}cout<<ans;return 0;
}

参考:Submission #43853592

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

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

相关文章

【运维】DevOps全流程笔记(未完成)

运维笔记 DevOps基本流程Code阶段工具&#xff08;gitlab安装&#xff09;Build阶段工具&#xff08;Maven安装&#xff09;Integrate阶段工具JenkinsJenkins介绍Jenkins安装Jenkins入门配置 CI/CD操作集成Sonar Qube集成HarborJenkins流水线Kubernetes编排工具 DevOps全流程笔…

uniApp低功耗蓝牙一键开门、多对多查找、数组匹配数组、开锁

文章目录 htmlJavaScript坑 html <view class"m_t_36"><view class"w_50_ h_100 lh_100 m_l_a m_r_a bc_409eff radius_10 color_fff ta_c" click"openBluetoothAdapter()">一键开门</view> </view>JavaScript export…

Golang ioutil包

ReadAll ReadAll方法&#xff0c;我们比较常用的工具类方法&#xff0c;一次性读取文件的所有内容并返回&#xff0c;适用于读取小文件&#xff0c;如果文件太大会占用太多内存。调用 ReadAll 方法成功&#xff0c;会读取 io.Reader的所有内容&#xff0c;返回的 err nil&…

怎么把PDF转为word?1分钟解决难题

PDF文件在我们的电脑上应用非常广泛&#xff0c;由于其较高的安全性和兼容性&#xff0c;得到了广泛的认可。然而&#xff0c;对于一些人来说&#xff0c;PDF文件不能直接进行编辑和修改可能是一个问题。因此&#xff0c;通常我们需要将其转换为Word格式&#xff0c;以便在Word…

[php-cos]ThinkPHP项目集成腾讯云储存对象COS

Cos技术文档 1、安装phpSdk 通过composer的方式安装。 1.1 在composer.json中添加 qcloud/cos-sdk-v5: >2.0 "require": {"php": ">7.2.5","topthink/framework": "^6.1.0","topthink/think-orm": "…

【Redis】Redis zset 实现排行榜

文章目录 前言案例程序设计score 设计 (相同积分的排序)缓存数据定时刷新当心缓存击穿 前言 排行榜是业务开发中常见的一个场景&#xff0c;如何设计一个好的数据结构能够满足高效实时的查询&#xff0c;下面我们结合一个实际例子来讨论一下。 案例 大概需求就是: 排行榜上显…

数据库监控工具-PIGOSS BSM

PIGOSS BSM 运维监控系统的重要功能之一是数据库监控&#xff0c;它能够帮助数据库管理员(DBA)和系统管理员监控包含Oracle、SQL Server、MySQL、DB2、PostgreSql、MongoDB、达梦、南大通用、人大金仓、神州通用等多种类异构型的数据库环境。PIGOSS BSM通过执行数据库查询来采集…

DSSAT模型教程

详情点击链接&#xff1a;R语言与作物模型&#xff08;DSSAT模型&#xff09;教程 前言 随着基于过程的作物生长模型&#xff08;Process-based Crop Growth Simulation Model&#xff09;的发展&#xff0c;R语言在作物生长模型和数据分析、挖掘和可视化中发挥着越来越重要的…

Python基础-列表(list)和元组(tuple)

Python包含6种内建的序列&#xff1a;列表&#xff0c;元组&#xff0c;字符串&#xff0c;Unicode字符串&#xff0c;buffer对象&#xff0c;xrange对象&#xff0c;本文讨论列表和元组。 1.列表可以修改&#xff0c;元组则不能修改。 2.几乎在所有的情况下&#xff0c;列表…

详细解析python视频选择--【思维导图知识范围】

C ,JAVA JAVAWEB ,微信小程序等 都有视频选择的分析。 语言视频选择收录专辑链接C张雪峰推荐选择了计算机专业之后-在大学期间卷起来-【大学生活篇】JAVA黑马B站视频JAVA部分的知识范围、学习步骤详解JAVAWEB黑马B站视频JAVAWEB部分的知识范围、学习步骤详解SpringBootSpringB…

Cesium:加载geojson面贴地和显示边界问题

1.背景 cesium加载geojson面数据后&#xff0c;有部分数据在地形下面显示不全&#xff0c; 加了clampToGround: true&#xff0c;设置贴地后&#xff0c;边界又不见了 this.viewer.dataSources.add(GeoJsonDataSource.load(http://xx/xzbj.geojson, {stroke: Color.BLACK.with…

保护隐私与安全的防关联、多开浏览器

随着互联网的不断发展&#xff0c;我们越来越离不开浏览器这个工具&#xff0c;它为我们提供了便捷的网络浏览体验。然而&#xff0c;随着我们在互联网上的活动越来越多&#xff0c;我们的个人信息和隐私也日益暴露在网络风险之下。在这种背景下&#xff0c;为了保护个人隐私和…

阿里Java开发手册~ORM 映射

1. 【强制】在表查询中&#xff0c;一律不要使用 * 作为查询的字段列表&#xff0c;需要哪些字段必须明确写明。 说明&#xff1a; 1 &#xff09; 增加查询分析器解析成本。 2 &#xff09; 增减字段容易与 resultMap 配置不一致。 2. 【强制】 POJO 类的 布尔 属性不…

PDF添加水印以及防止被删除、防止编辑与打印

方法记录如下&#xff1a; 1、添加水印&#xff1b; 2、打印输出成一个新的pdf&#xff1b; 3、将pdf页面输出成一张张的图片&#xff1a;&#xff08;福昕pdf操作步骤如下&#xff09; 4、将图片组装成一个新的pdf&#xff1a;&#xff08;福昕pdf操作步骤如下&#xff09;…

Android 任务调度 WorkManager 和 JobScheduler 的使用

在过去&#xff0c;常常使用后台Service来执行定时任务。虽然Service是执行后台任务的一种方式&#xff0c;但自Android 8.0&#xff08;API级别26&#xff09;以后&#xff0c;Google推荐使用更高效和系统友好的方式来执行定时任务&#xff0c;例如JobScheduler和WorkManager。…

flask实现一个登录界面

flask实现一个登录界面 基础的Flask项目结构 forms.py&#xff1a;定义登录表单和表单字段的文件。templates/login.html&#xff1a;用于渲染登录表单的 HTML 模板文件。routes.py&#xff1a;定义应用的路由和视图函数的文件。__init__.py&#xff1a;创建并初始化 Flask 应…

Java Spring和Spring集成Mybatis

0目录 1.Spring 2.Spring集成Mybatis 1.Spring 特性 IOC&#xff1a;控制反转 AOP&#xff1a;面向切面 Spring组成部分 在SMM中起到的作用&#xff08;粘合剂&#xff09; Spring理念 OOP核心思想【万物皆对象】 Spring核心思想【万物皆Bean组件】 Spring优势 低侵入式 …

MySQL学习笔记 ------ 排序查询

一、语法 SELECT 查询列表 FROM 表名 【WHERE 筛选条件】 ORDER BY 排序列表 【ASC}DESC】&#xff1b;#支持多个排序条件&#xff0c;以逗号分隔 二、特点 1、ASC &#xff1a;升序&#xff0c;如果不写默认升序 DESC&#xff1a;降序 2、排序列表 支持 单个字段…

基于新浪微博海量用户行为数据、博文数据数据分析:包括综合指数、移动指数、PC指数三个指数

基于新浪微博海量用户行为数据、博文数据数据分析&#xff1a;包括综合指数、移动指数、PC指数三个指数 项目介绍 微指数是基于海量用户行为数据、博文数据&#xff0c;采用科学计算方法统计得出的反映不同事件领域发展状况的指数产品。微指数对于收录的关键词&#xff0c;在指…

Java运算符

大体上&#xff0c;与C语言差不多&#xff0c;不同的地方&#xff0c;我用红色字体标注了 算术运算符 1. 基本四则运算符&#xff1a;加减乘除模 ( - * / %) int a 10 ; int b 20 ; System . out . println ( a b ); // 30 System . out . println ( a - b…