当前位置: 首页 > news >正文

USACO18DEC部分题 补题报告

一、Convention S

P5119 [USACO18DEC] Convention S

题意

给定大巴的数量,容量,奶牛的数量和到来的时间,要求合理安排大巴的发车时间使奶牛的等待时间最小,求出奶牛最大等待时间的最小值

思路

本题使用二分,输入之后进行排序,右端点为时间最大差值,二分中计算当前限制的等待时间下所需大巴数量,满足则向左继续二分,不满足则向右继续二分,直至左右端点同为一点

代码

#include<bits/stdc++.h>
using namespace std;
int n,m,c,t[100005],cnt,b[100005];
int main(){
//	freopen("convention.in","r",stdin);
//	freopen("convention.out","w",stdout);scanf("%d%d%d",&n,&m,&c);for(int i=1;i<=n;i++){scanf("%d",&t[i]);}sort(t+1,t+n+1);int l=0,r=t[n]-t[1];while(l<r){int mid=(l+r)/2;int k=1,j=1;for(int i=1;i<=n;i++){if(t[i]-t[j]>mid||i-j+1>c){j=i;k++;}}if(k<=m){r=mid;}else{l=mid+1;}}printf("%d\n",l);
//	fclose(stdin);
//	fclose(stdout);return 0;
}

二、Convention II S

P5120 [USACO18DEC] Convention II S

题意

给定奶牛的数量以及每个奶牛吃草的开始时间和吃草的用时,按照资历顺序输入,计算所有奶牛在队伍里等待的时间的最大值

思路

首先使用结构体记录每个奶牛的吃草开始时间,吃草用时和她的资历,然后按照到达时间的顺序进行排序,若时间相同,靠资历排序,然后按照时间顺序遍历每一只奶牛,若奶牛到达时有奶牛在吃,她必须等待(当前时间大于等于她到达的时间),就把她放进队列里比较,若她来时草地是空的(当前时间小于她到达的时间)且队列不为空(前面有需要等待的奶牛),我们就需要处理队列中的牛了,把当前时间和最长等待时间更新,进行完第二种情况的操作后,有可能处理完队列中的牛(队列为空),需要更新当前时间,有可能没有处理完队列里所有的奶牛当前时间就超过当前奶牛的到达时间了,我们就需要把这个奶牛也放到队列里去,遍历结束之后我们就可以得到最大的等待时间了

值得注意的是,这个题中我们用到了优先队列,优先队列的排序应按照奶牛的资历来进行,资历大的放前面,所以我们需要进行一个重载运算符的操作

代码

#include<bits/stdc++.h>
using namespace std;
struct node{int id;long long a,t;
}cow[100005];
bool cmp(node x,node y){if(x.a!=y.a){return x.a<y.a;}return x.id<y.id;
}
bool operator < (node x,node y){return x.id>y.id;
}
long long zeit,mtime,n;
priority_queue<node> q;
int main(){
//	freopen("convention.in","r",stdin);
//	freopen("convention.out","w",stdout);scanf("%d",&n);for(int i=1;i<=n;i++){cow[i].id=i;scanf("%lld%lld",&cow[i].a,&cow[i].t);}sort(cow+1,cow+1+n,cmp);for(int i=1;i<=n;i++){node c;if(cow[i].a<=zeit){c.id=cow[i].id,c.a=cow[i].a,c.t=cow[i].t;q.push(c);continue;}while(cow[i].a>zeit&&!q.empty()){c=q.top();q.pop();mtime=max(mtime,zeit-c.a);zeit+=c.t;}if(!q.empty()){c.id=cow[i].id,c.a=cow[i].a,c.t=cow[i].t;q.push(c);continue;}zeit=cow[i].a+cow[i].t;}printf("%d",mtime);
//	fclose(stdin);
//	fclose(stdout);return 0;
}

三、Mooyo Mooyo S

P5121 [USACO18DEC] Mooyo Mooyo S

题意

给定n和k以及棋盘的初始状态,棋盘是高n格,宽10格,每个格都有1,2,3,…,9共9种颜色,0代表空气,超过k个相同颜色的联通块会被消掉,然后其他格子受重力影响会落到底处,求最终的棋盘的状态

思路

题意就是计算联通块的数量,若大于给定的k就消掉(标记成0),然后把悬空的块都转移到地上,具体计算联通块的数量需要利用dfs,还需要定义一个布尔数组来确定是否被访问过,被访问过的格子不能再次访问,当然,每次操作结束后它都需要初始化,一旦统计出来的联通块数量超过了k,把所有访问过的点都赋值为‘0’,接下来就要进行下落的过程,这个过程需要倒着进行,从下向上进行,若发现有块,就需要尽可能的把它向下平移,到达下面有块或者棋盘界限的地方,整个过程大概就是这样的,我们还需要建立布尔变量来判断是否有活动(块下落或是消块),若没有,说明这个状态已经稳定

代码

#include<bits/stdc++.h>
using namespace std;
int fx[5]={0,0,1,0,-1};
int fy[5]={0,1,0,-1,0};
bool visited[105][15],flag;
int sum,n,k;
char mapp[105][15];
void dfs(int x,int y,int s){visited[x][y]=1;for(int i=1;i<=4;i++){int xx=x+fx[i];int yy=y+fy[i];if(visited[xx][yy]==0&&mapp[xx][yy]==s) {sum++;dfs(xx,yy,s);}}
}
void down(){for(int i=n;i>=1;i--) {for(int j=1;j<=10;j++) {if(mapp[i][j]!='0'){int k=i;while(mapp[k+1][j]=='0'&&k<=n){k++;}if(k!=i){mapp[k][j]=mapp[i][j];mapp[i][j]='0';}}}}
}
int main(){
//	freopen("convention.in","r",stdin);
//	freopen("convention.out","w",stdout);scanf("%d%d",&n,&k);for(int i=1;i<=n;i++) {for(int j=1;j<=10;j++) {cin>>mapp[i][j];}}flag=1;while(flag){flag=0;for(int i=1;i<=n;i++) {for(int j=1;j<=10;j++) {if(mapp[i][j]!='0') {sum=1;memset(visited,0,sizeof(visited));dfs(i,j,mapp[i][j]);if(sum>=k){for(int k=1;k<=n;k++){for(int l=1;l<=10;l++){if(visited[k][l]){mapp[k][l]='0';}}}flag=1;}}}}if(flag){down();}}for(int i=1;i<=n;i++) {for(int j=1;j<=10;j++) {cout<<mapp[i][j];}printf("\n");}
//	fclose(stdin);
//	fclose(stdout);return 0;
}

相关文章:

USACO18DEC部分题 补题报告

一、Convention S P5119 [USACO18DEC] Convention S 题意 给定大巴的数量&#xff0c;容量&#xff0c;奶牛的数量和到来的时间&#xff0c;要求合理安排大巴的发车时间使奶牛的等待时间最小&#xff0c;求出奶牛最大等待时间的最小值 思路 本题使用二分&#xff0c;输入之…...

聊一聊一些关于npm、pnpm、yarn的事

前言 整理了最近的闲聊&#xff0c;话题是前端各个包管理器&#xff0c;如果分享的不对或者有异议的地方&#xff0c;麻烦请及时告诉我~ 耐心看完&#xff0c;也许你会有所收获~ 概述 本文阅读时间&#xff1a;10-15分钟左右&#xff1b; 难度&#xff1a;初级&#xff0c…...

c语言多功能计算软件170

定制魏&#xff1a;QTWZPW&#xff0c;获取更多源码等 目录 题目 要求 主要代码片段 题目 设计一个计算器软件&#xff0c;具备如下功能提示界面。 要求 设计出界面&#xff0c;注意界面名称最后为自己的姓名&#xff1b;&#xff08;20分&#xff09;能够实现加、减、乘、…...

python图形化展示数据:保存为图片后查看

python debug时需要图像化展示数据&#xff0c;有三种方法。 方法一&#xff1a;t是值在[0, 255]之间的numpy数组&#xff0c;形状为 [ x ∗ x ∗ 3 ] [x*x*3] [x∗x∗3]&#xff0c;其中3为channel数。&#xff08;使用t.permute(1,2,0)变换通道&#xff0c;使用np.squeeze(t…...

PostgreSQL入门到实战-第二十四弹

PostgreSQL入门到实战 PostgreSQL中表连接操作(八)官网地址PostgreSQL概述PostgreSQL中CROSS JOIN命令理论PostgreSQL中CROSS JOIN命令实战更新计划 PostgreSQL中表连接操作(八) 使用PostgreSQL CROSS JOIN从连接的表中生成行的笛卡尔乘积。 官网地址 声明: 由于操作系统, 版…...

Spring Boot 统一功能处理(二)

本篇主要介绍Spring Boot统一功能处理中的统一数据返回格式。 目录 一、定义统一的返回类 二、配置统一数据格式 三、测试配置效果 四、统一格式返回的优点 五、源码角度解析String问题 一、定义统一的返回类 在我们的接口在处理请求时&#xff0c;返回的结果可以说是参…...

Flutter开发基础之动画专题

Flutter开发基础之动画专题 动画设计的作用是让UI界面更流畅、直观&#xff0c;能够有效的提升用户体验。 在Flutter开发中&#xff0c;动画分为多个方面&#xff1a; 基础动画、页面交互动画、绘图动画、矩阵变换等。 基本动画 常用的基本动画有透明度动画、缩放动画、旋转动…...

PHP 图片裁剪类封装

PHP工具类 图片裁剪类封装 <?php namespace App\Utils;/*** 图片裁剪工具类* author 田小涛* date 2020年7月23日* comment**/ class ImageCropUtils {private $sImage;private $dImage;private $src_file;private $dst_file;private $src_width;private $src_height;priv…...

Android 14.0 SystemUI修改状态栏电池图标样式为横屏显示

1.概述 在14.0的系统rom产品定制化开发中,对于原生系统中SystemUId 状态栏的电池图标是竖着显示的,一般手机的电池图标都是横屏显示的 可以觉得样式挺不错的,所以由于产品开发要求电池图标横着显示和手机的样式一样,所以就得重新更换SystemUI状态栏的电池样式了 如图: 2.S…...

FPGA:图像数字细节增强算法(工程+仿真+实物,可用毕设)

目录 日常唠嗑一、视频效果二、硬件及功能1、硬件选择2、功能3、特点 未完、待续……四、工程设计五、板级验证六、工程获取 日常唠嗑 有2个多月没写文章了&#xff0c;又是老借口&#xff1a;“最近实在是很忙”&#x1f923;&#xff0c;不过说真&#xff0c;确实是比较忙&am…...

Android netty的使用

导入netty依赖 implementation io.netty:netty-all:4.1.107.Final使用netty 关闭netty /*** 关闭*/private void closeSocket() {LogUtils.i(TAG, "closeSocket");if (nettyManager ! null) {nettyManager.close();nettyManager null;}if (nettyExecutor ! null) {…...

苹果电脑启动磁盘是什么意思 苹果电脑磁盘清理软件 mac找不到启动磁盘 启动磁盘没有足够的空间来进行分区

当你一早打开苹果电脑&#xff0c;结果系统突然提示&#xff1a; “启动磁盘已满&#xff0c;需要删除部分文件”。你会怎么办&#xff1f;如果你认为单纯靠清理废纸篓或者删除大型文件就能释放你的启动磁盘上的空间&#xff0c;那就大错特错了。其实苹果启动磁盘的清理技巧有很…...

【Java SE】多态

&#x1f970;&#x1f970;&#x1f970;来都来了&#xff0c;不妨点个关注叭&#xff01; &#x1f449;博客主页&#xff1a;欢迎各位大佬!&#x1f448; 文章目录 1. 多态1.1 多态是什么1.2 多态的意义1.3 多态的实现条件 2. 重写2.1 重写的概念2.2 重写的规则2.3 重写与重…...

Yarn vs npm的大同小异Yarn是什么?

Yarn vs npm的大同小异&Yarn是什么&#xff1f; 一、Yarn、npm是什么&#xff1f;二、Yarn vs npm&#xff1a;特性差异总结 一、Yarn、npm是什么&#xff1f; npm是Node.js的包管理器&#xff0c;是由Chris Korda维护。 npm,它全称为Node Package Manager&#xff0c;是…...

1.Godot引擎|场景|节点|GDS|介绍

Godot介绍 Godot是一款游戏引擎 可以通过在steam商城免费下载 初学者和编程基础稍差的推荐学习使用GDScript&#xff0c;和python有些相似 Godot节点 Godot的开发思想——围绕节点 节点的特征与优势 最常用基本的开发组件大部分都具有具体的功能&#xff0c;如图片&#xf…...

springboot3 redis 实现分布式锁

分布式锁介绍 分布式锁是一种在分布式系统中用于控制不同节点上的进程或线程对共享资源进行互斥访问的技术机制。 在分布式环境中&#xff0c;多个服务可能同时访问和操作共享资源&#xff0c;如数据库、文件系统等。为了保持数据的一致性和完整性&#xff0c;需要确保在同一…...

2024年第十四届MathorCup数学应用挑战赛A题思路分享(妈妈杯)

A题 移动通信网络中PCI规划问题 物理小区识别码(PCI)规划是移动通信网络中下行链路层上,对各覆盖小区编号进行合理配置,以避免PCI冲突、PCI混淆以及PCI模3干扰等现象。PCI规划对于减少物理层的小区间互相干扰(ICI),增加物理下行控制信道(PDCCH)的吞吐量有着重要的作用,尤其…...

运动听歌哪款耳机靠谱?精选五款热门开放式耳机

随着人们对运动健康的重视&#xff0c;越来越多的运动爱好者开始关注如何在运动中享受音乐。开放式蓝牙耳机凭借其独特的设计&#xff0c;成为了户外运动的理想选择。它不仅让你在运动时能够清晰听到周围环境的声音&#xff0c;保持警觉&#xff0c;还能让你在需要时与他人轻松…...

Kubernetes学习笔记12

k8s核心概念&#xff1a;控制器&#xff1a; 我们删除Pod是可以直接删除的&#xff0c;如果生产环境中的误操作&#xff0c;Pod同样也会被轻易地被删除掉。 所以&#xff0c;在K8s中引入另外一个概念&#xff1a;Controller&#xff08;控制器&#xff09;的概念&#xff0c;…...

Qt Designer 控件箱中的控件介绍及布局比列分配

控件箱介绍 Qt Designer的控件箱&#xff08;Widget Box&#xff09;包含了各种常用的控件&#xff0c;用户可以通过拖放的方式将这些控件添加到窗体设计器中&#xff0c;用于构建用户界面。以下是一些常见控件箱中的控件及其功能的讲解&#xff1a; 1.基本控件&#…...

Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?

Golang 面试经典题&#xff1a;map 的 key 可以是什么类型&#xff1f;哪些不可以&#xff1f; 在 Golang 的面试中&#xff0c;map 类型的使用是一个常见的考点&#xff0c;其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...

Zustand 状态管理库:极简而强大的解决方案

Zustand 是一个轻量级、快速和可扩展的状态管理库&#xff0c;特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...

条件运算符

C中的三目运算符&#xff08;也称条件运算符&#xff0c;英文&#xff1a;ternary operator&#xff09;是一种简洁的条件选择语句&#xff0c;语法如下&#xff1a; 条件表达式 ? 表达式1 : 表达式2• 如果“条件表达式”为true&#xff0c;则整个表达式的结果为“表达式1”…...

测试markdown--肇兴

day1&#xff1a; 1、去程&#xff1a;7:04 --11:32高铁 高铁右转上售票大厅2楼&#xff0c;穿过候车厅下一楼&#xff0c;上大巴车 &#xffe5;10/人 **2、到达&#xff1a;**12点多到达寨子&#xff0c;买门票&#xff0c;美团/抖音&#xff1a;&#xffe5;78人 3、中饭&a…...

高危文件识别的常用算法:原理、应用与企业场景

高危文件识别的常用算法&#xff1a;原理、应用与企业场景 高危文件识别旨在检测可能导致安全威胁的文件&#xff0c;如包含恶意代码、敏感数据或欺诈内容的文档&#xff0c;在企业协同办公环境中&#xff08;如Teams、Google Workspace&#xff09;尤为重要。结合大模型技术&…...

数据库分批入库

今天在工作中&#xff0c;遇到一个问题&#xff0c;就是分批查询的时候&#xff0c;由于批次过大导致出现了一些问题&#xff0c;一下是问题描述和解决方案&#xff1a; 示例&#xff1a; // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...

什么?连接服务器也能可视化显示界面?:基于X11 Forwarding + CentOS + MobaXterm实战指南

文章目录 什么是X11?环境准备实战步骤1️⃣ 服务器端配置(CentOS)2️⃣ 客户端配置(MobaXterm)3️⃣ 验证X11 Forwarding4️⃣ 运行自定义GUI程序(Python示例)5️⃣ 成功效果![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/55aefaea8a9f477e86d065227851fe3d.pn…...

pikachu靶场通关笔记22-1 SQL注入05-1-insert注入(报错法)

目录 一、SQL注入 二、insert注入 三、报错型注入 四、updatexml函数 五、源码审计 六、insert渗透实战 1、渗透准备 2、获取数据库名database 3、获取表名table 4、获取列名column 5、获取字段 本系列为通过《pikachu靶场通关笔记》的SQL注入关卡(共10关&#xff0…...

精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南

精益数据分析&#xff08;97/126&#xff09;&#xff1a;邮件营销与用户参与度的关键指标优化指南 在数字化营销时代&#xff0c;邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天&#xff0c;我们将深入解析邮件打开率、网站可用性、页面参与时…...

Java求职者面试指南:Spring、Spring Boot、MyBatis框架与计算机基础问题解析

Java求职者面试指南&#xff1a;Spring、Spring Boot、MyBatis框架与计算机基础问题解析 一、第一轮提问&#xff08;基础概念问题&#xff09; 1. 请解释Spring框架的核心容器是什么&#xff1f;它在Spring中起到什么作用&#xff1f; Spring框架的核心容器是IoC容器&#…...