Codeforces Round 975 (Div. 2)

传送门:https://codeforces.com/contest/2019

B. All Pairs Segments

题意:

首先样例解释一下:

一共有:[1,2],[1,3],[1,5],[1,6],[1,7],[2,3],[2,5],[2,6],[2,7],[3,5],[3,6],[3,7],[5,6],[5,7],[6,7]

点 1,7 在5个线段中包含,点2,4,6在9个线段中包含,点3,5在11个线段中包含

所以查询 5 时,输出2,查询9时,输出3 ...

思路:

                  1             2           3          5           6           7           假设一共有 n 个数

            

在 i 的下标中 左边一共有 i - 1 个数 ,右边有 n - i + 1,相互组合有 ( i - 1 ) * ( n - i + 1 )的贡献

并且 i 可以和右边的数组合 ,一共有 n - i 个贡献

如果没有出现在数组中,比如说 4 ,左边可以有 i - 1 个数,右边有 ( n - i + 1 ) 可以组合,所以有

( i - 1 ) * ( n - i + 1 ) 

AC代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
void solve()
{int n , q;cin >> n >> q;vector<int> a(n + 1);for( int i = 1; i <= n; i++) cin >> a[i];map<int,int> mp;for( int i = 1; i <= n; i++){mp[( i - 1 ) * ( n - i + 1 ) + n - i ]++;if( i > 1 )mp[(i - 1) * ( n - i + 1 )] += ( a[i] - a[i-1] - 1 );}while(q--){int x; cin >> x;cout << mp[x] << " ";}cout << endl;
}
signed main()
{int tt; cin >> tt;while(tt--)solve();return 0;
}

  C. Cards Partition

题意:

思路:

假设 mx 时 数组 a 的最大值,sum 是数组 a 的总和

假设牌的大小为  x ,所有牌的数量为 x * mx,但是还有一种可能 ( sum + x - 1 ) / x * x

AC代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
void solve()
{int n , k ; cin >> n >> k;vector<int> a(n + 1);for( int i = 1; i <= n; i++) cin >> a[i];int sum = 0; int mx = 0;for( int i = 1 ; i <= n; i++){sum += a[i]; mx = max( mx , a[i] );}int ans = 1;for( int i = 1 ; i <= n; i++){int temp = max( mx * i , ( sum + i - 1 ) / i * i ) ;if( temp <= sum + k ) ans = max( ans , i );}cout << ans << endl;
}
signed main()
{int tt; cin >> tt;while(tt--)solve();return 0;
}

E. Tree Pruning

题意:

思路:(拓扑排序)

AC代码:

#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N = 5e5 + 10;
int h[N], e[2 * N], ne[2 * N], idx;
int Size[N];
queue<int> que;
int leaf[N];
vector<int> dep[N];
bool vis[N]; int sum;
int deg[N];
void add(int a, int  b)
{e[idx] = b;ne[idx] = h[a];h[a] = idx++;
}
void dfs(int u, int fa, int depth)
{Size[u] = 1;dep[depth].push_back(u);for (int i = h[u]; i != -1; i = ne[i]){int j = e[i];if (j == fa)continue;dfs(j, u , depth + 1 );Size[u] += Size[j];}if (Size[u] == 1) {leaf[u] = 1;}
}
void topsort()
{while (que.size()){int x = que.front();que.pop();if (vis[x]) continue;vis[x] = true;sum++;for (int i = h[x]; i != -1; i = ne[i]){int j = e[i];if (j == 1) continue;if (--deg[j] <= 1)que.push(j);}}
}
void solve()
{int n; cin >> n;sum = 0; idx = 0;while (que.size())que.pop();for (int i = 0; i <= n; i++){leaf[i] = Size[i] = deg[i] = 0;vis[i] = false;h[i] = -1;dep[i].clear();}for (int i = 0; i < n - 1; i++){int a, b; cin >> a >> b;add(a, b); add(b, a);deg[a]++; deg[b]++;}dfs(1, -1, 0);int ans = 2e18;for (int i = 1; i < n; i++){int res = 0;for (auto e : dep[i]){res += Size[e] - 1;}ans = min(ans, res + sum);for (auto e : dep[i]){if (leaf[e]){que.push(e);}}topsort();}cout << ans << endl;
}
signed main()
{int tt; cin >> tt;while (tt--)solve();return 0;
}

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

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

相关文章

Mac电脑上最简单安装Python的方式

背景 最近换了一台新的 MacBook Air 电脑&#xff0c;所有的开发软件都没有了&#xff0c;需要重新配环境&#xff0c;而我现在最常用的开发程序就是Python。这篇文章记录一下我新Mac电脑安装Python的全过程&#xff0c;也给大家一些思路上的提醒。 以下是我新电脑的配置&…

Django项目配置日志

需求 在Django项目中实现控制台输出到日志文件&#xff0c;并且设置固定的大小以及当超过指定大小后覆盖最早的信息。 系统日志 使用Django自带的配置&#xff0c;可以自动记录Django的系统日志。 可以使用logging模块来配置。下面是一个完整的示例代码&#xff0c;展示了如…

Spring Boot 入门

Spring Boot 是基于 Spring 框架的简化开发框架&#xff0c;旨在通过减少配置工作&#xff0c;使开发人员可以快速上手构建 Java 应用。它提供了许多开箱即用的特性&#xff0c;例如嵌入式服务器、自动配置和约定优于配置等&#xff0c;极大地提升了开发效率。 以下是 Spring …

Java中通过方法上注解实现入参校验

设计思路 要通过注解实现对方法参数的校验&#xff0c;我们将利用Java的反射机制以及Spring AOP&#xff08;面向切面编程&#xff09;来实现。这种设计使得参数校验与业务逻辑解耦&#xff0c;提高了代码的可读性和可维护性。 1. 需求分析 自动化校验&#xff1a;不希望在每…

xxl-job 适配达梦数据库

前言 在数字化转型的浪潮中&#xff0c;任务调度成为了后端服务不可或缺的一部分。XXL-JOB 是一个轻量级、分布式的任务调度框架&#xff0c;广泛应用于各种业务场景。达梦数据库&#xff08;DM&#xff09;&#xff0c;作为一款国内领先的数据库产品&#xff0c;已经被越来越…

【笔记篇】Davinci Configurator OS模块(上)

目录 1 简介1.1 架构概览2 功能描述2.1 特性2.2 规范偏离2.2.1 API 函数的泛型偏离2.2.2 可信函数 API 偏离2.2.3 服务保护偏离2.2.4 代码保护2.2.5 SyncScheduleTable API 偏差2.2.6 CheckTask/ISRMemoryAccess API 偏差2.2.7 中断 API 偏差2.2.8 Cross Core Getter API2.2.9 …

Spring Boot 调用外部接口的常用方式!

使用Feign进行服务消费是一种简化HTTP调用的方式&#xff0c;可以通过声明式的接口定义来实现。下面是一个使用Feign的示例&#xff0c;包括设置Feign客户端和调用服务的方法。 添加依赖 首先&#xff0c;请确保你的项目中已经添加了Feign的依赖。如果你使用的是Maven&#xf…

Redis篇(应用案例 - 商户查询缓存)

目录 一、什么是缓存? 二、为什么要使用缓存 三、如何使用缓存 四、添加商户缓存 1. 缓存模型和思路 2. 代码如下 五、缓存更新策略 1. 内存淘汰 2. 超时剔除 3. 主动更新 六、数据库缓存不一致解决方案 1. 数据库缓存不一致解决方案 2. 数据库和缓存不一致采用什…

《关于浔川 AI 翻译 v3.0 延迟上线的通告》——浔川社团官方

尊敬的用户&#xff1a; 您好&#xff01; 首先&#xff0c;我们要向一直以来期待浔川 AI 翻译 v3.0 上线的各位用户致以最诚挚的歉意。原定于 [2024.9.19] 上线的浔川 AI 翻译 v3.0&#xff0c;由于 [安装失败原因]&#xff0c;将再次延迟至 2024 年 10 月 2 日上线。 我们…

AMD ROCm™ 安装指南

AMD ROCm™ installation — ROCm Blogs 注意: 本文之前是 AMD 实验笔记博客系列的一部分。 AMD ROCm™ 是第一个面向 HPC/超大规模级 GPU 计算的开源软件开发平台。AMD ROCm™ 将 UNIX 的选择权、极简主义和模块化软件开发哲学引入 GPU 计算领域。有关更多信息&#xff0c;请参…

【MySQL】函数及存储过程

MySQL函数和存储过程 函数 数据库中的函数是一种可重复使用的命名代码块&#xff0c;用于在数据库中执行特定的操作或计算。 在MySQL中提供了很多函数&#xff0c;为我们的SQL提供了便利 内置函数 mysql> select count(r_id),max(r_id),min(r_id),avg(r_id) from resume…

docker build 有时候不展示命令的输出情况,怎么办?

来源&#xff1a;https://stackoverflow.com/questions/64804749/why-is-docker-build-not-showing-any-output-from-commands docker build 有时候不展示命令的输出情况&#xff0c;不方便我们 debug&#xff0c;怎么办&#xff1f; 可以加上 docker build --progressplain …

C++和OpenGL实现3D游戏编程【连载10】——纹理的半透明显示

1、本节实现的内容 上一节课我们讲到了图片的镂空显示,它能在显示图片时去除指定颜色的背景,那么这节课我们来说一下图片的半透明显示效果,半透明效果能给画面带来更高质量的提升,使图片显示的更自然,产生更真实的效果。下面是一个气泡向上漂浮的效果。 气泡效果 2、非纹…

2024华为OD机试E卷-判断一组不等式是否满足约束并输出最大差-(C++/Java/Python)

2024华为OD机试最新E卷题库-(C卷+D卷+E卷)-(JAVA、Python、C++) 目录 题目描述 输入描述 输出描述 用例1 用例2 考点分析 题目解析 代码 c++ python java 题目描述 给定一组不等式,判断是否成立并输出不等式的最大差(输出浮点数的整数部分) 要求: 不等式系数为…

搜索引擎简介

搜索引擎架构 整个搜索引擎分为三个系统 爬虫系统 索引系统 线上搜素服务 爬虫系统 爬虫分为两个阶段&#xff1a; 第一阶段&#xff1a;根据目标网站的列表页&#xff0c;爬对应的文档 URL 第二阶段&#xff1a;根据文档 URL&#xff0c;下载文档内容 触发器&#xff1…

【行业报告】AI大模型对我国劳动力市场潜在影响研究报告(2024),附PDF下载!!

前言 9月13日&#xff0c;北京大学国家发展研究院联合智联招聘在中国国际服务贸易交易会上发布的《AI大模型对我国劳动力市场潜在影响研究&#xff1a;2024》&#xff08;以下简称“报告”&#xff09;显示&#xff0c;2024年上半年&#xff0c;招聘职位数同比增速前五的人工智…

数据结构——二叉树的性质和存储结构

二叉树的抽象类型定义 基本操作&#xff1a; CreateBiTree(&T&#xff0c;definition) 初始条件&#xff1a;definition给出二叉树T的定义。 操作结果:按definition构造二叉树T。 PreOrderTraverse(T) 初始条件:二叉树T存在。 操作结果:先序遍历T&#xff0c;对每个结…

基于Hive和Hadoop的白酒分析系统

本项目是一个基于大数据技术的白酒分析系统&#xff0c;旨在为用户提供全面的白酒市场信息和深入的价格分析。系统采用 Hadoop 平台进行大规模数据存储和处理&#xff0c;利用 MapReduce 进行数据分析和处理&#xff0c;通过 Sqoop 实现数据的导入导出&#xff0c;以 Spark 为核…

LLM | Ollama WebUI 安装使用(pip 版)

Open WebUI (Formerly Ollama WebUI) 也可以通过 docker 来安装使用 1. 详细步骤 1.1 安装 Open WebUI # 官方建议使用 python3.11&#xff08;2024.09.27&#xff09;&#xff0c;conda 的使用参考其他文章 conda create -n open-webui python3.11 conda activate open-web…

Java五子棋

目录 一&#xff1a;案例要求&#xff1a; 二&#xff1a;代码&#xff1a; 三&#xff1a;结果&#xff1a; 一&#xff1a;案例要求&#xff1a; 实现一个控制台下五子棋的程序。用一个二维数组模拟一个15*15路的五子棋棋盘&#xff0c;把每个元素赋值位“┼”可以画出棋…