题号 标题 已通过代码 题解/讨论 通过率 团队的状态
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的更多相关文章

  1. 2019nc#2

    A Eddy Walker 题意 你有n个点(0-n-1),按顺序形成一个环,初始时你在0的位子,你随机顺时针走一步或者逆时针走一步, 一旦你走到一个点后,环上所有点都被经过至少一次后,你就必须停下来 ...

  2. 2019nc#10

    题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Blackjack 点击查看 背包DP 32/109 补好了 B Coffee Chicken 点击查看 进入讨论 738/2992  通过 ...

  3. 2019NC#8

    题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A All-one Matrices 点击查看 单调栈+前缀和 326/2017  通过 B Beauty Values 点击查看 进入讨论 8 ...

  4. 2019nc#7

    题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A String 点击查看 进入讨论 566/3539  通过 B Irreducible Polynomial 点击查看 规律 730/229 ...

  5. 2019nc#6

    https://ac.nowcoder.com/acm/contest/886#question 题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Garbage Classificatio ...

  6. 2019nc#5

    题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A digits 2 点击查看 1017/2384  通过 B generator 1 点击查看 567/3692  通过 C generato ...

  7. 2019nc#4

    题号 标题 已通过代码 题解 通过率 团队的状态 A meeting 点击查看 树直径 604/2055   B xor 点击查看 线段树维护线性基交 81/861 未通过 C sequence 点击 ...

  8. 2019nc#3

    题号 标题 已通过代码 题解/讨论 通过率 团队的状态 A Graph Games 点击查看 进入讨论 18/292 未通过 B Crazy Binary String 点击查看 1107/3615 ...

  9. 2019NC#1

    LINK B Integration 题意: 给定$a_1,a_2,...,a_n$, 计算 $$\frac{1}{π}\int_{0}^{\infty}\frac{1}{\prod\limits_{ ...

随机推荐

  1. GGPLOT2-plotly |让你的火山图“活”过来

    火山图(Volcano Plot)常用于展示基因表达差异的分布,横坐标常为Fold change(倍数),越偏离中心差异倍数越大;纵坐标为P值(P值),值越大差异越显着.原因得名也许的英文因为查询查询 ...

  2. MyBatis在Spring环境下的事务管理

    MyBatis的设计思想很简单,可以看做是对JDBC的一次封装,并提供强大的动态SQL映射功能.但是由于它本身也有一些缓存.事务管理等功能,所以实际使用中还是会碰到一些问题--另外,最近接触了JFin ...

  3. 第三章、Go-内建容器

    3.1.数组 (1)数组的定义 package main import ( "fmt" ) func main() { //用var定义数组可以不用赋初值 var arr1 [5] ...

  4. codeforces 339A.Helpful Maths B.Xenia and Ringroad 两水题

    A.题意就是把字符串里面的数字按增序排列,直接上代码. #include <string.h> #include <stdio.h> #include <algorith ...

  5. 极力推荐一个简单好用的C++JSON库

      极力推荐一个简单好用的C++JSON库CJsonObject,让使用json如使用C++原生的结构体那般方便,随心所欲.CJsonObject是个优秀的C++JSON库,也许会是你见过的最为简单易 ...

  6. Selenium+java - 调用JavaScript操作

    前言 在做web自动化时,有些情况selenium的api无法完成,需要通过第三方手段比如js来完成实现,比如去改变某些元素对象的属性或者进行一些特殊的操作,本文将来讲解怎样来调用JavaScript ...

  7. Tomcat源码分析 (三)----- 生命周期机制 Lifecycle

    Tomcat里面有各种各样的组件,每个组件各司其职,组件之间又相互协作共同完成web服务器这样的工程.在这些组件之上,Lifecycle(生命周期机制)至关重要!在学习各个组件之前,我们需要看看Lif ...

  8. 常见Http协议状态码

    收集常见的http协议状态码,供查阅!包括中文和英文对照. 中文版 1**:请求收到,继续处理 2**:操作成功收到,分析.接受 3**:完成此请求必须进一步处理 4**:请求包含一个错误语法或不能完 ...

  9. 用python写排序算法

    希尔排序 希尔排序通过将比较的全部元素分为几个区域来提升插入排序的性能.这样可以让一个元素可以一次性地朝最终位置前进一大步.然后算法再取越来越小的步长进行排序,算法的最后一步就是普通的插入排序,但是到 ...

  10. The 3n + 1 problem UVA - 100

    3n+1问题 PC/UVa IDs: 110101/100 Popularity: A Success rate: low Level: 1 测试地址: https://vjudge.net/prob ...