2019nc#9
题号 | 标题 | 已通过代码 | 题解/讨论 | 通过率 | 团队的状态 |
---|---|---|---|---|---|
A | The power of Fibonacci | 点击查看 | 进入讨论 | 69/227 | 未通过 |
B | Quadratic equation | 点击查看 | 高次剩余 | 391/888 | 未通过 |
C | Inversions of all permutations | 点击查看 | 进入讨论 | 28/61 | 未通过 |
D | Knapsack Cryptosystem | 点击查看 | 进入讨论 | 606/2251 | 通过 |
E | All men are brothers | 点击查看 | 进入讨论 | 425/1117 | 通过 |
F | Birthday Reminders | 点击查看 | 进入讨论 | 5/11 | 未通过 |
G | Checkers | 点击查看 | 进入讨论 | 0/15 | 未通过 |
H | Cutting Bamboos | 点击查看 | 二分,主席树 | 187/834 | 通过 |
I | KM and M | 点击查看 | 进入讨论 | 19/296 | 未通过 |
J | Symmetrical Painting | 点击查看 | 进入讨论 | 227/930 | 通过 |
H Cutting Bamboos
这道题用主席树过的,记录下区间权值。
// #pragma GCC optimize(2)
// #pragma GCC optimize(3)
// #pragma GCC optimize(4)
#include <algorithm>
#include <iterator>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <iomanip>
#include <bitset>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <stack>
#include <cmath>
#include <queue>
#include <list>
#include <map>
#include <set>
#include <cassert>
#include <unordered_map>
// #include<bits/extc++.h>
// using namespace __gnu_pbds;
using namespace std;
#define pb push_back
#define fi first
#define se second
#define debug(x) cerr<<#x << " := " << x << endl;
#define bug cerr<<"-----------------------"<<endl;
#define FOR(a, b, c) for(int a = b; a <= c; ++ a) typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll; const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f;
const int mod = 1e9+; template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
}
/**********showtime************/ const int N = 2e5 + , M = 4e6 + ;//M为节点个数,为Q*log(N)
int root[N], lson[M], rson[M], value[M], tot = ;
ll sum[M];
const double eps = 1e-;
//建树
void build(int &x, int l, int r) {
x = ++tot;
value[x] = ;
sum[x] = ;
if(l == r) {
return ;
}
int m = (l+r) >> ;
build(lson[x], l, m);
build(rson[x], m+, r);
value[x] = value[lson[x]] + value[rson[x]];
}
// 将某个历史版本p位置的值加v
void update(int old, int &x, int p, int v, int l, int r) {
x = ++tot;
lson[x] = lson[old], rson[x] = rson[old], value[x] = value[old] + v, sum[x] = sum[old] + p;
if(l == r) return ;
int m = (l+r) >> ;
if(p <= m) update(lson[x], lson[x], p, v, l, m);
else update(rson[x], rson[x], p, v, m+, r);
}
//访问某个历史版本L到R的区间和
int query(int L, int R, int x, int l, int r) {
if(L <= l && r <= R) return value[x];
int m = (l+r) >> , ans = ;
if(L <= m) ans += query(L, R, lson[x], l, m);
if(R > m) ans += query(L, R, rson[x], m+, r);
return ans;
}
ll query2(int L, int R, int x, int l, int r) {
if(L <= l && r <= R) return sum[x];
int m = (l+r) >> ;
ll ans = ;
if(L <= m) ans += query2(L, R, lson[x], l, m);
if(R > m) ans += query2(L, R, rson[x], m+, r);
return ans;
}
const int maxn = 2e5+;
ll pre[maxn], a[maxn];
double cal(double val, int L, int R) {
int hi = floor(val);
int cnt = query(, hi, root[R], , ) - query(, hi, root[L-], , );
double ss = (R - L + - cnt) * val;
ss += 1.0*query2(, hi,root[R], , ) - query2(, hi, root[L-], , );
return ss;
}
int main(){
int n,m;
scanf("%d%d", &n, &m);
build(root[], , );
for(int i=; i<=n; i++) {
scanf("%lld", &a[i]), pre[i] = pre[i-] + a[i];
update(root[i-], root[i], a[i], , , );
}
while(m--) {
int L, R, x, y;
scanf("%d%d%d%d", &L, &R, &x, &y);
ll ss = pre[R] - pre[L-];
double nd = ss*1.0 / y *(y - x);
double le = , ri = , res = ;
//debug(nd);
while(le + eps < ri) {
double mid = (le + ri) / ;
if(cal(mid, L, R) <= nd) le = mid, res = mid;
else ri = mid;
}
printf("%.10f\n", res);
}
return ;
}
J Symmetrical Painting
题意:
有n个矩形,宽度都为1,排列在坐标轴上,问消去一些矩形的一部分,使得原来的图形上下对称。这个对称图形最大可能面积。
思路:
有点类似扫描线的做法。
/*
* @Author: chenkexing
* @Date: 2019-08-16 15:34:14
* @Last Modified by: chenkexing
* @Last Modified time: 2019-08-16 15:41:12
*/ // #pragma GCC optimize(2)
// #pragma GCC optimize(3)
// #pragma GCC optimize(4)
#include <algorithm>
#include <iterator>
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <iomanip>
#include <bitset>
#include <cctype>
#include <cstdio>
#include <string>
#include <vector>
#include <stack>
#include <cmath>
#include <queue>
#include <list>
#include <map>
#include <set>
#include <cassert>
// #include<bits/extc++.h>
// using namespace __gnu_pbds;
using namespace std;
#define pb push_back
#define fi first
#define se second
#define debug(x) cerr<<#x << " := " << x << endl;
#define bug cerr<<"-----------------------"<<endl;
#define FOR(a, b, c) for(int a = b; a <= c; ++ a) typedef long long ll;
typedef long double ld;
typedef pair<int, int> pii;
typedef pair<ll, ll> pll; const int inf = 0x3f3f3f3f;
const ll inff = 0x3f3f3f3f3f3f3f3f;
const int mod = ; template<typename T>
inline T read(T&x){
x=;int f=;char ch=getchar();
while (ch<''||ch>'') f|=(ch=='-'),ch=getchar();
while (ch>=''&&ch<='') x=x*+ch-'',ch=getchar();
return x=f?-x:x;
} /**********showtime************/
const int maxn = ;
pii a[maxn * ]; int main(){
int n;
scanf("%d", &n);
int tot = ;
for(int i=; i<=n; i++) {
int le,ri;
scanf("%d%d", &le, &ri);
// 在底,中点,高上有可能取到极值。
a[++tot] = pii(*le, );
a[++tot] = pii(le + ri, -);
a[++tot] = pii(*ri, );
}
sort(a+, a++tot);
ll ans = , sum = ;
ll cnt = a[].se;
for(int i=; i<=tot; i++) {
sum += cnt * (a[i].fi - a[i-].fi);
ans = max(ans, sum);
cnt += a[i].se;
}
printf("%lld\n", ans);
return ;
}
2019nc#9的更多相关文章
- 2019nc#2
A Eddy Walker 题意 你有n个点(0-n-1),按顺序形成一个环,初始时你在0的位子,你随机顺时针走一步或者逆时针走一步, 一旦你走到一个点后,环上所有点都被经过至少一次后,你就必须停下来 ...
- 2019nc#10
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Blackjack 点击查看 背包DP 32/109 补好了 B Coffee Chicken 点击查看 进入讨论 738/2992 通过 ...
- 2019NC#8
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A All-one Matrices 点击查看 单调栈+前缀和 326/2017 通过 B Beauty Values 点击查看 进入讨论 8 ...
- 2019nc#7
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A String 点击查看 进入讨论 566/3539 通过 B Irreducible Polynomial 点击查看 规律 730/229 ...
- 2019nc#6
https://ac.nowcoder.com/acm/contest/886#question 题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Garbage Classificatio ...
- 2019nc#5
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A digits 2 点击查看 1017/2384 通过 B generator 1 点击查看 567/3692 通过 C generato ...
- 2019nc#4
题号 标题 已通过代码 题解 通过率 团队的状态 A meeting 点击查看 树直径 604/2055 B xor 点击查看 线段树维护线性基交 81/861 未通过 C sequence 点击 ...
- 2019nc#3
题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Graph Games 点击查看 进入讨论 18/292 未通过 B Crazy Binary String 点击查看 1107/3615 ...
- 2019NC#1
LINK B Integration 题意: 给定$a_1,a_2,...,a_n$, 计算 $$\frac{1}{π}\int_{0}^{\infty}\frac{1}{\prod\limits_{ ...
随机推荐
- redis订阅者与发布者
#conding=utf-8 #一.创建redis类 文件名 RedisHelper import redis # conn=redis.Redis(host='127.0.0.1')# import ...
- 【iOS】the executable was signed with invalid entitlements
又遇到了这个问题,貌似之前遇到过,如图所示: 原因:开发证书里没添加手机. PS: Xcode7 除外,据说已经不需要证书了,这里用的是 6.4
- 【OpenCV-ANN神经网络自动驾驶】树莓派OpenCV神经网络自动驾驶小车【源码+实物】
没错!这个是我的毕业设计!!! 整个电子信息学院唯一一个优秀毕业设计 拿到这里炫耀了 实物如下: 电脑端显示效果: 自动驾驶实现过程: 1. 收集图像数据.建立局域网,让主机和Raspberry Pi ...
- ipv6的连接
基础知识不说了,网上一大堆! 基本内容不说了,写字太累了! 只说三点细节,记住就行: 1.ff开头的是多播地址,只能用于udp多播 2.fe80开头的是本地link地址,不管ping也好,connec ...
- ImageView 使用详解
极力推荐文章:欢迎收藏 Android 干货分享 阅读五分钟,每日十点,和您一起终身学习,这里是程序员Android 本篇文章主要介绍 Android 开发中的部分知识点,通过阅读本篇文章,您将收获以 ...
- win10和浏览器快捷键
1. Win10快捷键[Win+↑/↓/←/→] 将当前窗口按比例固定到屏幕的四个边角,如左上.右上.左下.右下.[Win+1/2/3…] 按顺序打开任务栏上的已固定程序(不包括第一个“任务视图”按钮 ...
- [Spring cloud 一步步实现广告系统] 15. 使用开源组件监听Binlog 实现增量索引准备
MySQL Binlog简介 什么是binlog? 一个二进制日志,用来记录对数据发生或潜在发生更改的SQL语句,并以而进行的形式保存在磁盘中. binlog 的作用? 最主要有3个用途: 数据复制( ...
- LayDate使用
layDate非常愿意和您成为工作伙伴.她致力于成为全球最用心的web日期支撑,为国内外所有从事web应用开发的同仁提供力所能及的动力.她基于原生JavaScript精心雕琢,兼容了包括IE6在内的所 ...
- 减谈迷宫C++
今天老师让做了个迷宫问题,我一看到就发现和我之前写过的一个程序是一样 的,但是在后来编写的时候有一个地方搞错了,最后下课了我还是没有正确的编写好,然后今天回来之后自己有看了一下,现在已经解决了. #i ...
- PCB学习总结
一.电子设计流程概述:项目立项------元件创库----------原理图设计-----------封装绘制-------pcb设计--------生产文件的输出--------pcb文件加工 二. ...