技术标签: 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;
}
文章浏览阅读3.3w次。前言在审批场景中,有这么个需求,某个节点需要多个人审批,但这些人需要按照一定的顺序进行审批才算完成,这就需要用到activity串行多实例会签;下面就来探讨一下在这种场景下的具体实现1、定义流程文件该图和上一篇的差不多,需要修改的地方在于,Sequential的这个参数需要勾选上,意思就是说,在节点为多实例的情形下,是否顺序审批,默认为false,即其中多个任务审批时没有顺序的2、部署并启动流程实例 public static void main(String[] args) { _activities 多实例
文章浏览阅读2.6w次,点赞20次,收藏84次。一 。IP地址分类我们将IP地址分为了【A B C D E】五大类,但是D和E不对民用组织开放,所以我们能使用IP地址的只有ABC三类。判断四组IP的第一个数组来确定是哪类。【注意:127.0.0.1不再里面,是因为它代表当前计算机自己】二。判断每一类IP是否属于一个网段(一)A类1. A类IP用第一个数字来表示不同网段。例如:1.0.0.0和2.0.0.0是不同的网络..._判断ip是否在一个网段
文章浏览阅读313次。基本网页标签将一个网页看成人的话,那么一个网页标签也分别有表示皮肤、头、脸、身体的部位<html> <head> <!--head中一般写入一些浏览器中的配置标签--> <meta charset='utf-8' /> <title> 这是我的第一个网页</title> </head> &..._html中最基本的标签aheadbhtmlctitle
文章浏览阅读668次。最近阿里冲容量,拿些压箱底的东西出来吧。没有注册的,可以用我的链接注册一下,再用手机app登一下,咱们各享500G空间。我在使用不限速「阿里云盘」,赠送你 500GB 快来试试吧------------我在使用不限速「阿里云盘」,赠送你 500GB 快来试试吧 ------------点此链接领取福利:https://pages.aliyundrive.com/mobile-page/web/beinvited.html?code=21ed59d1 信号与系统包括以下内._放大器设计实践125问全解
文章浏览阅读2.6k次,点赞5次,收藏2次。目录开始--管理工具--组策略管理进入组策略界面在主域下编辑DefaultDomainPolicy按照以下路径打开策略编辑器可移动存储访问U盘策略和光盘策略分开特殊情况测试域策略立即生效客户端生效生效效果开始--管理工具--组策略管理进入组策略界面在主域下编辑DefaultDomainPolicy按照以下路径打开策略编辑器可移动存储访问可移动光盘:控制U盘的读取、执行、写入权限CD和DVD:控制光盘的读取、执行、写入权._域控关闭自动打开u盘策略
文章浏览阅读206次。信源字符表可以是二进制的,也可使多字符的,非二进制字符可以通过一个字符编码表映射为二进制码字;③x7和x8合并后的复合字符的概率为P(x7)+P(x8)=1/8,并将新得到一组字符按照概率不增大的次序排列,注意:新复合字符与x3和x4概率相同,可放置在x2和x5之间的任何位置,此例子放置在x4之后,替换x5。等长码中表示每个字符的码字长度是相同的,但是各字符所含有的信息量是不同的。等长码可以通过计数的方法确定字符的分界,但变长码则不可以,接收端收到一长串变长码,不一定能确定每个字符的分界。_霍夫曼压缩编码
文章浏览阅读154次。一、网络函数(1)htons(2)inet_addr 点格式转换为无符号长整型 ina.sin_addr.s_addr = inet_addr("132.241.5.10");(3)inet_ntoa 无符号长整型转换为点格式 struct in_addr addr1; ulong l1; l1= inet_addr("192.168.0.74"..._linux实现代码的指令
文章浏览阅读1.1k次。在这个例子中,字符串"hello world!"被移动,使得输出为 “hello hello world!是一个标准库函数,用于 C++ 中的内存操作。它主要用于在内存中移动或复制字节。可以处理源内存区和目标内存区重叠的情况。如果源内存区和目标内存区重叠,此函数会返回指向目标内存区的指针。仍然可以正确地复制字节,而。_void *memmove(void *dest, const void *src, size_t n);
文章浏览阅读140次。一 、工作环境 操作系统:Windows Server 2008 R2 SP1 x64 Apache版本:2.4.4 Subversion版本: Setup-Subversion-1.7.10.msi TortoiseSVN版本:TortoiseSVN-1.7.13.24257-x64-svn-1.7.10.msi +LanguagePack_1.7.13.24257..._windows subversion x64
文章浏览阅读1.1k次。我得到了一些东西作为Excel的线性拟合,使用scipy basinhopping而不是曲线拟合和大量迭代。运行迭代需要一点时间,而且还需要一个错误函数,但它是在没有缩放原始数据的情况下完成的。Basinhopping docs.import numpy as npimport matplotlib.pyplot as pltfrom scipy.optimize import basinhopp..._一阶线性拟合斜率
文章浏览阅读376次。广西医科大学融水函授站成人大专考试试卷课程:计算机应用基础专业:班级:姓名:学号:一、Word与Excel部分1.编辑排版一个文档完毕后,若要知道其打印效果,可选择( A )功能。A.打印预览 B.模拟打印 C.提前打印 D。屏幕打印2.Word窗口中打开文档MWA,修改后另存为MWC,则文档( B )。A.MWA是当前文档 B.MWC是当前文档C.MWC和MWA都是当前文档 D.MWC和MWA均...
文章浏览阅读104次。--更改MSSQL数据库物理文件名Sql语句的写法--注意:要在活动监视器里面确保没有进程连接你要改名的数据库!!!!!!!!!!!!!!!!!!!!-- Sql语句如下USE master --改逻辑名ALTER DATABASE YQBlog MODIFY FILE(NAME='YQBlogAA',NEWNAME='YQBlog') -- GOALTER..._tdsql修改数据库名称