技术标签: ACM题目整理
if (r <= mid) return query(2 * u, l, r);
,递归的时候不是 query(2 * u, l, mid)
!#include<iostream>
#include<algorithm>
#include<cstring>
typedef unsigned long long ll;
using namespace std;
const int maxn = 1000010;
const ll M = 1e12;
int p[maxn];
ll sum[maxn];
int find(int x){
if (p[x] == x) return x;
return p[x] = find(p[x]);
}
void unite(int a, int b) {
if (find(a) == find(b)) return;
p[a] = find(b);
}
unsigned long long k1, k2;
int N;
long long a[1000001];
unsigned long long xorShift128Plus() {
unsigned long long k3 = k1, k4 = k2;
k1 = k4;
k3 ^= k3 << 23;
k2 = k3 ^ k4 ^ (k3 >> 17) ^ (k4 >> 26);
return k2 + k4;
}
void gen() {
scanf("%d %llu %llu", &N, &k1, &k2);
for (int i = 1; i <= N; i++) {
a[i] = xorShift128Plus() % 999999999999 + 1;
}
}
struct node {
int l, r;
ll sum;
}tr[maxn * 4];
void pushup(int u) {
tr[u].sum = tr[2 * u].sum + tr[2 * u + 1].sum;
}
void build(int u, int l, int r) {
if (l == r) tr[u] = {
l, l, 0 };
else {
tr[u].l = l, tr[u].r = r;
int mid = (l + r) / 2;
build(2 * u, l, mid), build(2 * u + 1, mid + 1, r);
//pushup(u);
}
}
node query(int u, int l, int r) {
if (l <= tr[u].l && tr[u].r <= r) return tr[u];
int mid = (tr[u].l + tr[u].r) / 2;
if (r <= mid) return query(2 * u, l, r);
else if (l > mid) return query(2 * u + 1, l, r);
else {
node left = query(2 * u, l, r);
node right = query(2 * u + 1, l, r);
node res;
res.sum = left.sum + right.sum;
return res;
}
}
void modify(int u, int x, ll v) {
// a[x] = v;
if (tr[u].l == x && tr[u].r == x) tr[u].sum = v;
else {
int mid = (tr[u].l + tr[u].r) / 2;
if (x <= mid) modify(2 * u, x, v);
else modify(2 * u + 1, x, v);
pushup(u);
}
}
int main() {
gen();
sort(a + 1, a + N + 1);
//for (int i = 1; i <= N; i++) printf("%llu ", a[i]);
for (int i = 1; i <= N; i++) {
sum[i] = sum[i - 1] + a[i];
}
int Q;
scanf("%d", &Q);
build(1, 1, N);
for (int i = 1; i <= N + 1; i++) {
p[i] = i;
}
while (Q--) {
char op[5];
ll x;
scanf("%s%llu", op, &x);
if (op[0] == 'D') {
// 标记>=x的第一个未被标记的a[i]
int id = lower_bound(a + 1, a + N + 1, x) - a;
int pos = find(id);
if (pos == N + 1) continue;
unite(pos, pos + 1);
modify(1, pos, a[pos]);
}
if (op[0] == 'F') {
// 查询>=x的第一个未被标记的a[i]
int id = lower_bound(a + 1, a + N + 1, x) - a;
int pos = find(id);
if (pos == N + 1) printf("%llu\n", M);
else {
printf("%llu\n", a[pos]);
}
}
if (op[0] == 'R') {
// <=x的标记全部清零
int id = upper_bound(a + 1, a + N + 1, x) - a - 1;
if (id == 0) continue;
for (int i = 1; i <= id; i++) {
p[i] = i;
modify(1, i, 0);
}
}
if (op[0] == 'C') {
//查询小于等于 x 的所有未标记数之和;若没有,则输出0。
int id = upper_bound(a + 1, a + N + 1, x) - a - 1;
if (id == 0) printf("0\n");
else {
printf("%llu\n", sum[id] - query(1, 1, id).sum);
}
}
}
return 0;
}
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
typedef long long ll;
typedef pair<ll, ll> P;
const ll mod = 1e9 + 7;
ll mod_pow(ll x, ll n) {
ll res = 1;
while (n) {
if (n & 1) res = res * x % mod;
x = x * x % mod;
n >>= 1;
}
return res;
}
ll gcd(ll a, ll b) {
if (b == 0) return a;
return gcd(b, a % b);
}
ll p[7];
void calc(ll a, ll b, ll c) {
//相当于把八个点带入直线方程,求D的值
P Ds[8] = {
P(0, 0), P(a, 1), P(b, 1), P(c, 1),
P(a + b, -1), P(b + c, -1), P(a + c, -1), P(a + b + c, 0) };
sort(Ds, Ds + 8);
ll edges = 3, last_D = Ds[0].first;
for (int i = 1; i < 8; i++) {
p[edges] += (Ds[i].first - last_D);
last_D = Ds[i].first;
edges += Ds[i].second;
}
}
int main() {
int T;
scanf("%d", &T);
while (T--) {
memset(p, 0, sizeof p);
ll a, b, c, A, B, C;
scanf("%lld%lld%lld%lld%lld%lld", &a, &b, &c, &A, &B, &C);
A = abs(A), B = abs(B), C = abs(C);
if (A && B && C) calc(a * A, b * B, c * C);
//只要 A, B, C 有一个0,那么一定是与四个棱交点(与某个棱重合的概率可以认为是0,因为点的长度是0嘛)。
else {
p[4] = 1;
}
ll sum = 0;
for (int i = 3; i <= 6; i++) {
sum += p[i];
}
for (int i = 3; i <= 6; i++) {
ll d = gcd(p[i], sum);
ll ans = (p[i] / d) * mod_pow(sum / d, mod - 2) % mod;
printf("%lld%c", ans, i == 6 ? '\n' : ' ');
}
}
return 0;
}
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
using namespace std;
const int maxn = 1010, maxm = 1000010;
int h[maxn], e[maxm], ne[maxm], idx;
int x[maxn], y[maxn], N, d[maxn];
int din[maxn];
void add(int a, int b) {
e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}
void toposort() {
d[0] = 0;
queue<int> que;
for (int i = 0; i <= N; i++) {
if (din[i] == 0) que.push(i);
}
while (que.size()) {
int u = que.front(); que.pop();
for (int i = h[u]; i != -1; i = ne[i]) {
int v = e[i];
d[v] = max(d[v], d[u] + 1);
if (--din[v] == 0) que.push(v);
//printf("### %d %d\n", u, v);
}
}
}
int main() {
int T;
scanf("%d", &T);
while (T--) {
memset(h, -1, sizeof h);
memset(d, -0x3f, sizeof d);
memset(din, 0, sizeof d);
idx = 0;
scanf("%d%d", &x[0], &y[0]);
scanf("%d", &N);
for (int i = 1; i <= N; i++) {
scanf("%d%d", &x[i], &y[i]);
}
for (int i = 1; i <= N; i++) {
for (int j = 0; j <= N; j++) {
if (i == j) continue;
if (abs(x[i] - x[j]) <= y[i] - y[j] + 1) {
add(j, i);
din[i]++;
}
}
}
toposort();
int ans = 0;
for (int i = 0; i <= N; i++) {
ans = max(ans, d[i]);
}
printf("%d\n", ans);
}
return 0;
}
#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;
const int maxn = 1010, maxm = 1000010;
int h[maxn], e[maxm], ne[maxm], idx;
int x[maxn], y[maxn], N, d[maxn];
int din[maxn];
bool vis[maxn];
void add(int a, int b) {
e[idx] = b, ne[idx] = h[a], h[a] = idx++;
}
int dp(int u) {
if (vis[u]) return d[u];
d[u] = 0;
vis[u] = true;
for (int i = h[u]; i != -1; i = ne[i]) {
int v = e[i];
d[u] = max(d[u], dp(v) + 1);
}
return d[u];
}
int main() {
int T;
scanf("%d", &T);
while (T--) {
memset(vis, false, sizeof vis);
memset(h, -1, sizeof h);
memset(d, -0x3f, sizeof d);
memset(din, 0, sizeof d);
idx = 0;
scanf("%d%d", &x[0], &y[0]);
scanf("%d", &N);
for (int i = 1; i <= N; i++) {
scanf("%d%d", &x[i], &y[i]);
}
for (int i = 1; i <= N; i++) {
for (int j = 0; j <= N; j++) {
if (i == j) continue;
if (abs(x[i] - x[j]) <= y[i] - y[j] + 1) {
add(j, i);
din[i]++;
}
}
}
d[0] = 0;
printf("%d\n", dp(0));
}
return 0;
}
rt = find(fa[v.idx]);
ans += rt.b * v.a;
nodes[rt].b += v.b, nodes[rt].a += v.a;
#include<iostream>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
typedef long long ll;
const int maxn = 100010;
struct node {
int idx;
ll a, b;
bool operator <(const node& rhn)const {
return b * rhn.a < rhn.b * a;
}
}nodes[maxn];
int p[maxn], fa[maxn];
bool vis[maxn];
int find(int x) {
if (p[x] == x) return x;
return p[x] = find(p[x]);
}
void unite(int a, int b) {
if (find(a) == find(b)) return;
p[a] = find(b);
}
int main() {
int N;
scanf("%d", &N);
for (int i = 1; i <= N; i++) p[i] = i;
for (int i = 2; i <= N; i++) {
scanf("%d", &fa[i]);
}
priority_queue<node> que;
for (int i = 1; i <= N; i++) {
scanf("%lld%lld", &nodes[i].a, &nodes[i].b);
nodes[i].idx = i;
if (i != 1) que.push(nodes[i]);
}
ll ans = 0;
while (que.size()) {
auto v = que.top(); que.pop();
if (vis[v.idx]) continue;
vis[v.idx] = true;
int rt = find(fa[v.idx]);
ans += nodes[rt].b * v.a;
nodes[rt].b += v.b, nodes[rt].a += v.a;
unite(v.idx, rt);
if (rt != 1 && !vis[rt]) que.push(nodes[rt]);
}
printf("%lld\n", ans);
return 0;
}
文章浏览阅读1.2k次。webrtc_mediasoup拥塞控制
文章浏览阅读4.8k次。外部再加层SingleChildScrollView属性this.scrollDirection = Axis.vertical,//滚动的方向,垂直或水平this.reverse = false,// 是否反转,如果是垂直滚动的话,reverse默认为false,表示先看上面。如果reverse为true,则先看底部。this.padding,// 内边距bool primary,// 是否使用默认的controllerthis.physics,this.controller,//可以控制初_flutter 超出滚动
文章浏览阅读3.7k次。minecraft很多人不知道皮肤和披风怎么换,装了mod也没用,皮肤有人说必须要正版,也是胡扯。那该怎么换呢?下面是学习啦小编收集整理的minecraft我的世界局域网换皮肤和披风,希望对大家有帮助~~minecraft我的世界局域网换皮肤和披风工具/原料minecraft电脑版skinme方法/步骤1进入http://www.skinme.cc/#./mod_index?&_suid=..._minecraft披风网站
文章浏览阅读457次。简单实现思路:对图像内容进行分割,提取人像对图像背景进行模糊化处理将人像和背景重新合成在这里,使用DeepLabV3模型对图像内容进行分割并提取人像,实现的代码如下:import numpy as npimport tensorflow as tfimport cv2from deeplabmodel import *def create_pascal_label_colormap():color..._python 图像处理 深度学习
文章浏览阅读180次。一段时间没写公众号了,最近写了个 burpsuite 数据收集的插件,于是想出一篇从头编写一个 burpsuite 插件的教程。这个插件的目的收集 burpsuite 请求中的数据,如请求中的子域名、文件名、目录名、参数名等,保存到数据库,然后根据出现的次数进行排序,出现次数多的排在前面,从而强化我们的字典。插件效果演示先来看看插件的效果图:该插件会在 burp 上面新建一个标签页,用来...
文章浏览阅读3.2k次。从Excel小白到慢慢深刻领悟函数,这一路我见证了她的成长,下面我们一起来看看她带给我们的内容吧~=====手动分割线====昨天我学习了Excel的IF函数,基础语法其实很简单,因为网上很多关于IF函数的讲解大多是用单个条件来讲解的,确实是很容易理解,但也只是单一条件下的IF函数运用。实际情况往往我们的判断条件是不止一个的,并且IF函数的魅力就在于此,面对多条件,就要考虑IF函数的的嵌套了,IF..._[任务1]使用if完成嵌套选择。说明:从键盘输入性别,用字符f'代表女,"m'代表男,若为女性则输出“欢迎女士您的光临!”,男性则要求输入年龄,判断年龄是已经成年,成年则输出“欢迎xx岁您的光临!”。。
文章浏览阅读1.1k次。DETECT是一个在graphics.h头文件中定义的常量,用于在初始化图形模式时指定使用自动检测功能。你在使用DETECT之前没有包含graphics.h头文件或者在编译时graphics.h文件没有找到,因此导致编译器无法识别DETECT标识符,出现了“未定义标识符”的错误提示。你需要在使用DETECT之前包含graphics.h头文件,例如:#include <graphics...._未定义标识符detect
文章浏览阅读830次。C语言语法变量变量对应这内存中的一段内存。 从内存的角度看变量,变量包括:内存地址(变量首地址)、变量名、变量类型(即变量大小)、变量值等。关键字auto自动变量:是函数的参数 ,和 在函数体内定义的局部变量。函数的形参及代码块中定义的变量都属于auto变量,这是C语言中应用最广的一种变量,这类变量是栈分配的,是动态分配存储空间的。举函数形参为例,当调用该函数时,为形参分配存储空间,当函数调用结束时,系统就自动释放这些存储空间。对**代码块中定义的变量(包含函数中定义的变量),当执行到_00,,c
文章浏览阅读1.7w次,点赞12次,收藏32次。极坐标与笛卡尔坐标极坐标与笛卡尔坐标笛卡尔坐标系极坐标系转换笛卡尔坐标转换为极坐标极坐标转换为笛卡尔坐标但如果 X 和 Y 是负数呢?总结极坐标与笛卡尔坐标笛卡尔坐标系极坐标系转换从一个系统转换到另一系统,我们用这个三角形:笛卡尔坐标转换为极坐标当我们知道一点的笛卡尔坐标 (x,y)(x,y)(x,y) 想转换成极坐标 (r,θ)(r,θ)(r,θ),我们需要解一个有两条已知边的直角三角形。例子: (12,5) 的极坐标是什么?用勾股定理去计算长的一边(斜边):r2=122+52r=_笛卡尔转极坐标
文章浏览阅读557次。用cfd post 输出eps格式图片时,会莫名其妙地出现一些点,比如,原本要输出一条曲线,但是多了下面这个点。怎么办?辛亏eps文件可以编辑!!!先保留上面的那条线,输出test1.eps然后把线隐藏,再输出test2.eps然后用notepad++把两个eps文件都打开。使用compare插件,比较这两个文本。会发现,test1.eps中多出了一些命令其中有这么几行数据,是以v或者vc结尾的。..._cfdpost导出图片关闭水印
文章浏览阅读707次。无论是经由降压、升压、降压/升压或线性稳压器驱动,连接每一个驱动电路最常见的线程就是须要控制光的输出。现今仅有很少数的应用只需要开和关的简单功能,绝大多数都需要从0~100%去微调光度。目前,针对光度控制方面,主要的两种解决方案为线性调节LED的电流(模拟调光)或在肉眼无法察觉的高频下,让驱动电流从0到目标电流值之间来回切换(数字调光)。利用脉冲宽度调变(PWM)来设定循环和工作周期可能是实现数字..._.xp pwma1wdpjppwm1ptgp7pgdppp0mpwpg邓文747778547146009977ggdppwppgg1ppp
文章浏览阅读178次。掐指一算,距离国庆黄金周还有半个月的时间!你出行的车票都抢到了吗?图片来自 pexels根据国务院办公厅发布的关于 2019 年部分节假日安排的通知,国庆放假安排是:10 月 1 日至 7 日。想要十一出行的小伙伴们,想必前几天刚经历了一波抢票大战。顺便把一个 Python 抢票工具,送到了 GitHub 趋势榜第一。这个项目名很干脆,就是“12306”,目前标星超过 12K。项目发起者是一名叫文..._将配置中的 web_enable 打开,启动程序后访问当前主机地址 + 端口号 (默认 8008)