Codeforces Round 665 (Div. 2) (A-F)

A.Problem - A - Codeforces

        (1)题意

                给你个X轴,初始A点在n这个位置,O在源点0,问你要把B放在哪才能让|AB-BO| = k,最小化A需要移动多少次。

        (2)思路

                直接分情况套路即可。

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 2e5 + 10;
void solve()
{int n,k;cin >> n >> k;int Ans = 0;if((n + k) & 1) {Ans ++;n ++;}if(k > n) Ans += k - n;cout << Ans << '\n';
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;cin >> T;while(T --) solve();return 0;
}

B.Problem - B - Codeforces

        (1)题意

                a序列有x1个0,y1个1,z1个2,b序列有x2个0,y2个1,z2个2,给定你这个函数,问你在任意排序后可以获得的最大价值是多少。

                

        (2)思路

                贪心考虑,肯定是先把有价值的拿了,然后把其他的都给弄成0,否则就只能加上负贡献了。       

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 2e5 + 10;
void solve()
{int x1,y1,z1;int x2,y2,z2;int Ans = 0;cin >> x1 >> y1 >> z1;cin >> x2 >> y2 >> z2;int mi = min(z1,y2);y2 -= mi,z1 -= mi;Ans += mi * 2;mi = min(z1,z2);z1 -= mi,z2 -= mi;mi = min(z1,x2);z1 -= mi,x2 -= mi;mi = min(y1,y2);y1 -= mi,y2 -= mi;mi = min(y1,x2);y1 -= mi,x2 -= mi;mi = min(x1,z2);x1 -= mi,z2 -= mi;mi = min(x1,y2);x1 -= mi,y2 -= mi;mi = min(y1,y2);y1 -= mi,y2 -= mi;mi = min(x1,x2);x1 -= mi,x2 -= mi;mi = min(z1,z2);z1 -= mi,z2 -= mi;mi = min(y1,z2);Ans -= 2 * mi;cout << Ans << '\n';
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;cin >> T;while(T --) solve();return 0;
}

C.Problem - C - Codeforces

        (1)题意

                给你一个长为n的序列,设最小值为Mi,你每次可以选择两个数a[i]和a[j],若gcd(a[i],a[j])=Mi,问你是否可以把这个序列变成不降序列。

        (2)思路

                很显然我们可以直接把%Mi为0的所有数拿出来,从大到小依次放入原序列,最后检查原序列是否不降即可。

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 2e5 + 10;
int a[N];
void solve()
{int n;cin >> n;int mi = 1e9;vector<int> v;rep(i,1,n) {cin >> a[i];mi = min(mi,a[i]);}rep(i,1,n) {if(a[i] % mi == 0) {v.pb(a[i]);}}sort(v.rbegin(),v.rend());rep(i,1,n) {if(a[i] % mi == 0) {a[i] = v.back();v.pop_back();}}rep(i,2,n) {if(a[i] < a[i - 1]) {cout << "NO" << '\n';return;}}cout << "YES" << '\n';
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;cin >> T;while(T --) solve();return 0;
}

D.Problem - D - Codeforces

        (1)题意

                给你棵N个节点的树,和一个总权值K,要你把K分配给这颗树的N-1条边,满足这些树边相乘等于K,并且分配的边权1的数量最少,问你任意两个点的所有边权和加起来最大为多少?

        (2)思路

                我们可以计算出每条边经过多少次,因此考虑贪心分配边权即可,若K分解的质因子大于当前n - 1,则需要把后面的补成1即可,否则可以把多余的补给经过次数最多的那条边即可。

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 1e5 + 10;
vector<int> g[N];
ll f[N],siz[N];
int n;
const ll mod = 1e9 + 7;
inline void dfs(int u,int f)
{siz[u] = 1;for(auto v : g[u]) {if(v == f) continue;dfs(v,u);siz[u] += siz[v];}
}
void solve()
{   cin >> n;rep(i,1,n) g[i].clear();rep(i,2,n) {int u,v;cin >> u >> v;g[u].pb(v),g[v].pb(u);}int k;cin >> k;vector<ll> z;rep(i,1,k) cin >> f[i];dfs(1,0);rep(i,2,n) z.pb(siz[i] * (n - siz[i]));ll Ans = 0;if(sz(z) >= k) {sort(f + 1,f + 1 + k,[&](ll &c,ll &d){return c > d;});sort(z.rbegin(),z.rend());while(sz(z) > k) f[++ k] = 1;rep(i,1,sz(z)) Ans = (Ans + f[i] * z[i - 1] % mod) % mod;}else {sort(f + 1,f + 1 + k,[&](ll &c,ll &d){return c < d;});sort(z.begin(),z.end());ll tmp = 1,res = k - sz(z);for(int i = k - res + 1;i <= k;i ++) tmp = tmp * f[i] % mod;f[sz(z)] = f[sz(z)] * tmp % mod;rep(i,1,sz(z)) Ans = (Ans + f[i] * z[i - 1] % mod) % mod;}cout << Ans << '\n';
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;cin >> T;while(T --) solve();return 0;
}

E.Problem - E - Codeforces

        (1)题意

                给你N条平行X轴的线,和M条平行Y轴的线,保证每一条线都与边框至少有一个交点,且每一条线不重合,问你最后会分出来多少个矩形。

        (2)思路

                这种题目一般是看交点就行了,因此我们观察样例很容易得出结论,答案=交点个数+1+本身交边框有两交点的线。

                那么我们可以用值域树状数组维护出来即可,用树状数组代表横坐标为多少时有一条长度为y的线,然后对于每一条平行Y轴的线做区间查找即可得出交点个数。

        (3)代码实现

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 1e6 + 10;
template <typename T>
struct Fenwick {const int n;std::vector<T> a;Fenwick (int n) : n(n), a(n + 1) {}void add(int pos, T x) {for (int i = pos; i <= n; i += i & -i) {a[i] += x;}}T query(int x) {T res = 0;for (int i = x; i; i -= i & -i) {res += a[i];}return res;}T query(int l, int r) {if (l == 0 || l > r) {return 0;}return query(r) - query(l - 1);}//找到大于k得第一个地方T kth(int k) {int pos = 0;for(int j = 31 - __builtin_clz(n);j >= 0;j --) {if(pos + (1 << j) <= n && k > a[pos + (1 << j)]) {pos += 1 << j;k -= a[pos];}}return pos + 1;}
};
//使用Fenwick<ll> fen(n)
vector<PII> a[N],b[N];
void solve()
{int n,m;cin >> n >> m;Fenwick<int> fen(1000001);ll Ans = 1;rep(i,1,n) {int y1,x1,x2;cin >> y1 >> x1 >> x2;a[x1].pb({y1 + 1,1});a[x2 + 1].pb({y1 + 1,-1});if(x1 == 0 && x2 == 1000000) Ans ++;}rep(i,1,m) {int x1,y1,y2;cin >> x1 >> y1 >> y2;b[x1].pb({y1 + 1,y2 + 1});if(y1 == 0 && y2 == 1000000) Ans ++;}rep(i,0,1000000) {for(auto [x,w]: a[i]) {fen.add(x,w);}for(auto [l,r] : b[i]) {Ans += fen.query(l,r);}}cout << Ans;
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;// cin >> T;while(T --) solve();return 0;
}

F.Problem - F - Codeforces

        (1)题意        (2)思路

                第一个操作和第四个操作是线段树基本操作,因此不需要管,重点观察第二个操作和第三个操作,首先这颗线段树是一颗完美二叉树,包含的区间都是2^i次方,对于reverse操作来说,就是把第(k + 1)层线段树的节点的左右儿子交换,那么swap操作,其实也就是对于每一层线段树节点的左右儿子进行交换,那么这个问题就是个简单的线段树了,交换直接在外边维护好就行了。

        (3)代码

#include <bits/stdc++.h>
#define rep(i,z,n) for(int i = z;i <= n; i++)
#define per(i,n,z) for(int i = n;i >= z; i--)
#define PII pair<int,int>
#define fi first
#define se second
#define vi vector<int>
#define vl vector<ll>
#define pb push_back
#define sz(x) (int)x.size()
#define all(x) (x).begin(),(x).end()
using namespace std;
using ll = long long;
const int N = 3e5 + 10;
ll tr[N << 2];
int a[N],rev[N];
inline void build(int u,int l,int r)
{if(l == r) {tr[u] = a[l];return;}int mid = (l + r) >> 1;build(u << 1,l,mid);build(u << 1 | 1,mid + 1,r);tr[u] = tr[u << 1] + tr[u << 1 | 1];
}
inline void modify(int u,int l,int r,int dep,int p,int x)
{if(l == r) {tr[u] = x;return;}int mid = (l + r) >> 1;if(p <= mid) modify(u << 1 ^ rev[dep],l,mid,dep - 1,p,x);else modify(u << 1 | 1 ^ rev[dep],mid + 1,r,dep - 1,p,x);tr[u] = tr[u << 1] + tr[u << 1 | 1];
}
inline ll query(int u,int l,int r,int dep,int ql,int qr)
{if(l >= ql && r <= qr) return tr[u];int mid = (l + r) >> 1;ll s = 0;if(ql <= mid) s += query(u << 1 ^ rev[dep],l,mid,dep - 1,ql,qr);if(qr > mid) s += query(u << 1 | 1 ^ rev[dep],mid + 1,r,dep - 1,ql,qr);return s;
}
void solve()
{int n,q;cin >> n >> q;rep(i,1,(1 << n)) cin >> a[i];build(1,1,(1 << n));while(q --) {int op,l,r;cin >> op;if(op == 1) {cin >> l >> r;modify(1,1,(1<<n),n,l,r);}else if(op == 2) {cin >> l;for(int i = 0;i <= l;i ++) rev[i] ^= 1;}else if(op == 3) {cin >> l;rev[l + 1] ^= 1;}else {cin >> l >> r;cout << query(1,1,(1<<n),n,l,r) << '\n';}}
}
int main()
{ios::sync_with_stdio(false);cin.tie(0),cout.tie(0);int T = 1;// cin >> T;while(T --) solve();return 0;
}

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

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

相关文章

MySQL约束

文章目录 简单介绍主键约束添加单列主键多列主键删除主键 自增长约束(auto_increment)语法&#xff1a;指定自增字段初始值 非空约束唯一约束(unique)默认约束(default)零填充约束(zerofill) 简单介绍 概念&#xff1a;表中数据的约束条件 作用&#xff1a;表在设计的时候加入…

用AI原生向量数据库Milvus Cloud 搭建一个 AI 聊天机器人

搭建聊天机器人 一切准备就绪后,就可以搭建聊天机器人了。 文档存储 机器人需要存储文档块以及使用 Towhee 提取出的文档块向量。在这个步骤中,我们需要用到 Milvus。 安装轻量版 Milvus Lite,使用以下命令运行 Milvus 服务器: (chatbot_venv) [egoebelbecker@ares milvus_…

Python与Scrapy:构建强大的网络爬虫

网络爬虫是一种用于自动化获取互联网信息的工具&#xff0c;在数据采集和处理方面具有重要的作用。Python语言和Scrapy框架是构建强大网络爬虫的理想选择。本文将分享使用Python和Scrapy构建强大的网络爬虫的方法和技巧&#xff0c;帮助您快速入门并实现实际操作价值。 一、Pyt…

QSS之QComboBox

QComboBox在Qt开发过程中经常使用&#xff0c;默认的下载列表风格达不到设计师的要求&#xff0c;本篇介绍基本的QComboBox的qss设置。 属性意思QComboBoxQComboBox基本样式QComboBox:editable右边可选择按钮QComboBox:!editable, QComboBox::drop-down:editable不可编辑或下拉…

从“概念”到“应用”,字节跳动基于 DataLeap 的 DataOps 实践

更多技术交流、求职机会&#xff0c;欢迎关注字节跳动数据平台微信公众号&#xff0c;回复【1】进入官方交流群 近日&#xff0c;火山引擎数智平台 VeDI Meetup「超话数据」在深圳举办&#xff0c;来自火山引擎的产品专家分享了字节跳动基于 DataLeap 的 DataOps 实践&#xff…

Audacity 使用教程:轻松录制、编辑音频

Audacity 使用教程&#xff1a;轻松录制、编辑音频 1. 简介 Audacity 是一款免费、开源且功能强大的音频录制和编辑软件。它适用于 Windows、Mac 和 Linux 等多种操作系统&#xff0c;适合音乐制作、广播后期制作以及普通用户进行音频处理。本教程将带领大家熟悉 Audacity 的…

管道-匿名管道

一、管道介绍 管道&#xff08;Pipe&#xff09;是一种在UNIX和类UNIX系统中用于进程间通信的机制。它允许一个进程的输出直接成为另一个进程的输入&#xff0c;从而实现数据的流动。管道是一种轻量级的通信方式&#xff0c;用于协调不同进程的工作。 1. 创建和使用管道&#…

机器人中的数值优化|【七】线性搜索牛顿共轭梯度法、可信域牛顿共轭梯度法

机器人中的数值优化|【七】线性搜索牛顿共轭梯度法、可信域牛顿共轭梯度法 Line Search Newton-CG, Trust Region Newton-CG 往期回顾 机器人中的数值优化|【一】数值优化基础 机器人中的数值优化|【二】最速下降法&#xff0c;可行牛顿法的python实现&#xff0c;以Rosenbro…

解决Invalid bound statement (not found)错误~

报错如下所示&#xff1a; 找了好久&#xff0c;刚开始以为是名称哪里写的有问题&#xff0c;但仔细检查了好多遍都不是 最后发现了问题如下所示&#xff1a; UserMapper里面的内容被我修改了&#xff0c;但classes中的内容还是原来的内容&#xff0c;所以才导致了编译器报错n…

【计算机网络】HTTP协议详解(举例解释,超级详细)

文章目录 一、HTTP协议简单介绍 1、1 什么是HTTP协议 1、2 再次理解“协议” 二、HTTP请求 2、1 HTTP的工作过程 2、1、1 demo代码 2、2 URL 介绍 2、2、1 urlencode 和 urldecode 2、3 HTTP 请求格式 三、HTTP响应 3、1 响应demo 3、2 HTTP 响应格式 四、HTTP 请求和响应中的…

【改进哈里鹰算法(NCHHO)】使用混沌和非线性控制参数来提高哈里鹰算法的优化性能,解决车联网相关的路由问题(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…

ENVI报错:SaveRasterFile failed:IDLnaMetadata Error

ENVI报错&#xff1a;SaveRasterFile failed:IDLnaMetadata Error 问题描述 ENVI在另存为为TIFF文件时&#xff0c;报了下面这个错误信息 原因 输出路径或者是存放影像的路径里面包含中文&#xff0c;不能包含中文 解决方案 把所有相关路径中的中文改成英文

嵌入式学习笔记(42)SD卡的编程接口

8.3.1 SD卡的物理接口 SD卡由9个针脚与外界进行物理连接&#xff0c;这9个脚中有2个地&#xff0c;1个电源&#xff0c;6个信号线。 8.3.2 SD协议与SPI协议 (1)SD卡与SRAM/DDR/SROM之类的东西的不同&#xff1a;SRAM/DDR/SROM之类的存储芯片是总线式的&#xff0c;只要连接上…

深入学习git

1、git原理及整体架构图 一些常用的命令 git add . 或 git add src/com/ygl/hello/hello.java 指定文件 git commit . 或 git commit src/com/ygl/hello/hello.java 指定文件 git push origin 分支名称 2、git stash的应用场景 场景一&#xff1a;你正在当前分支A开发&…

司空见惯 - 奈尔宝的NTTP

联合国对21世纪人才定义的标准&#xff0c;包括六种核心技能&#xff0c;即批判性思维&#xff08;critical thinking)、人际交往&#xff08;communication)、与人合作&#xff08;collaboration)、创造性&#xff08;creativity)、信息素养&#xff08;information literacy)…

controller-manager学习三部曲之一:通过脚本文件寻找程序入口

欢迎访问我的GitHub 这里分类和汇总了欣宸的全部原创(含配套源码)&#xff1a;https://github.com/zq2599/blog_demos 关于《controller-manager学习三部曲》 《controller-manager学习三部曲》是欣宸原创的kubernetes深入学习系列之一&#xff0c;在前面的《client-go实战》系…

弧度、圆弧上的点、圆的半径(r)、弧长(s)之间的关系

要计算弧度和圆弧上的点&#xff0c;需要知道以下几个要素&#xff1a; 圆的半径&#xff08;r&#xff09;&#xff1a;即圆的中心到圆周上任意一点的距离。 弧长&#xff08;s&#xff09;&#xff1a;从圆周上的一个点到另一个点所经过的弧长。 弧度&#xff08;θ&#x…

ADO连接Access的前期绑定方法实例(下)

【分享成果&#xff0c;随喜正能量】眾生多悲苦&#xff0c;發願‬菩提心。願今天所有聽見我、看見我、憶念我的眾生&#xff0c;因我心而‬生喜悅&#xff01;除消身心的痛苦&#xff01;種下脫解‬的種子&#xff01;願我等‬身心念力所及之處一切眾切‬生因佛得度&#xff0…

CSS基础语法第二天

目录 一、复合选择器 1.1 后代选择器 1.2 子代选择器 1.3 并集选择器 1.4 交集选择器 1.4.1超链接伪类 二、CSS特性 2.1 继承性 2.2 层叠性 2.3 优先级 基础选择器 复合选择器-叠加 三、Emmet 写法 3.1HTML标签 3.2CSS 四、背景属性 4.1 背景图 4.2 平铺方式 …

CF505B Mr. Kitayuta‘s Colorful Graph

Mr. Kitayuta’s Colorful Graph 题面翻译 给出一个 n n n 个点&#xff0c; m m m 条边的无向图&#xff0c;每条边上是有颜色的。有 q q q 组询问 对于第 i i i 组询问&#xff0c;给出点对 u i , v i u_i,v_i ui​,vi​。求有多少种颜色 c c c 满足&#xff1a;有至…