题目描述



区间绝对众数

即出现次数>len/2下取整的数

对于区间[L,R]扫一遍,维护一个数x和出现次数s

当前数=x则s+1,否则s-1,若s已为0则把x设为当前数

若区间内存在绝对众数,那么就算用其他的数和其抵消后仍然能剩余

因此最后的x就是可能的绝对众数(当区间内存在时)


推广到本题,设d=100/p下取整,对于线段树内每个区间维护d个可能的强国

显然一个国家在两个区间内都是弱国的话合并后不可能变成强国,因此可能的强国只有这2d个国家

合并一下,若合并后多于d个就把第d+1个去消前d个

原理同上,一个强国一次会消掉至少d个数,全部消完后还有剩余

而题目又允许出现弱国,所以可以这样搞

code

#include <bits/stdc++.h>
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
#define ll long long
#define file
using namespace std; char ch;
void get(int &x)
{
x=0;
ch=getchar();
while (ch<'0' || ch>'9') ch=getchar();
while (ch>='0' && ch<='9') x=x*10+(ch-'0'),ch=getchar();
}
void put(int x)
{
int a[8],len=0; if (!x) putchar('0');
while (x) {a[++len]=x%10;x/=10;}
while (len) {putchar(a[len--]+'0');}
} int a[150001],Tr[600001],n,Q,p,d,tp,i,j,k,l,x,y,z; //Tr<0:1 >0:2
struct type{
int x,s;
inline void clear() {x=s=0;}
};
bool cmp(type a,type b) {return a.s>b.s;}
struct arr{
type a[11]; inline void clear() {int i;fo(i,1,10) a[i].clear();}
void merge(arr b)
{
int i,j,N=0,tot=0; fo(i,1,d) if (a[i].s) N=tot=i; else break;
fo(i,1,d)
if (b.a[i].s)
{
fo(j,1,N)
if (b.a[i].x==a[j].x)
{a[j].s+=b.a[i].s;break;} if (j>N)
a[++tot]=b.a[i];
}
else
break; if (tot)
{
stable_sort(a+1,a+tot+1,cmp); if (tot>d)
{
fo(i,1,d)
{
a[i].s-=a[d+1].s;
if (!a[i].s)
a[i].x=0;
}
tot=d;
}
}
fo(i,tot+1,10) a[i].clear();
}
} tr[600001],ans; int merge(int x,int y)
{
if (!x || y<0) return y;
if (x<0) return x-y;
return x+y;
} void down(int t,int len)
{
int i; if (Tr[t])
{
if (len>1) Tr[t*2]=merge(Tr[t*2],Tr[t]),Tr[t*2+1]=merge(Tr[t*2+1],Tr[t]); if (Tr[t]<0)
{
tr[t].clear();
tr[t].a[1]={-Tr[t],len};
}
else
{
fo(i,1,d)
if (tr[t].a[i].s)
tr[t].a[i].x+=Tr[t];
else
break;
} Tr[t]=0;
}
} void up(int t)
{
tr[t]=tr[t*2];
tr[t].merge(tr[t*2+1]);
} void mt(int t,int l,int r)
{
int mid=(l+r)/2; if (l==r)
{
tr[t].a[1]={a[l],1};
return;
} mt(t*2,l,mid);
mt(t*2+1,mid+1,r); up(t);
} void change(int t,int l,int r,int x,int y,int s)
{
int mid=(l+r)/2; down(t,r-l+1);
if (x<=l && r<=y)
{
Tr[t]=s;
down(t,r-l+1);
return;
} down(t*2,mid-l+1);
down(t*2+1,r-mid); if (x<=mid)
change(t*2,l,mid,x,y,s);
if (mid<y)
change(t*2+1,mid+1,r,x,y,s); up(t);
} void find(int t,int l,int r,int x,int y)
{
int mid=(l+r)/2; down(t,r-l+1);
if (x<=l && r<=y)
{
ans.merge(tr[t]);
return;
} if (x<=mid)
find(t*2,l,mid,x,y);
if (mid<y)
find(t*2+1,mid+1,r,x,y);
} int main()
{
freopen("war.in","r",stdin);
#ifdef file
freopen("war.out","w",stdout);
#endif get(n);get(Q);get(p);d=100/p;
fo(i,1,n) get(a[i]);
mt(1,1,n); for (;Q;--Q)
{
get(tp); if (Q<0 || n!=150000)
n=n; switch (tp)
{
case 1:{
get(x);get(y);get(z); change(1,1,n,x,y,-z);
break;
}
case 2:{
get(x);get(y); change(1,1,n,x,y,1);
break;
}
case 3:{
get(x);get(y);
ans.clear();
find(1,1,n,x,y); fo(k,1,d)
if (!ans.a[k].s)
{break;}
--k; put(k);putchar(' ');
fo(i,1,k)
put(ans.a[i].x),putchar(' ');
putchar('\n');
break;
}
}
} fclose(stdin);
fclose(stdout); return 0;
}

6487. 【GDOI2020模拟02.29】列强争霸war的更多相关文章

  1. 6485. 【GDOI2020模拟02.25】沙塔斯月光

    题目描述 题解 镇♂男则反 如果没有操作3很好办,反着做维护操作1的次数即可 实际上一次操作3的贡献是zi*(∑i到操作1位置的距离) 维护一下即可O(n^4) code #include <b ...

  2. JZOJ 5184. 【NOIP2017提高组模拟6.29】Gift

    5184. [NOIP2017提高组模拟6.29]Gift (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  3. [jzoj NOIP2018模拟10.29]

    OI生涯的最高分,来了纪中这么多天,在经历了这么多场“NOIP难度”的模拟赛之后,终于看到了真正的NOIP 今天考场上效率很高,很快码完了全部的题目,留下了足够的时间对拍和...发呆.不得不说看着电脑 ...

  4. 「模拟8.29」chinese(性质)·physics·chemistry(概率期望)

    T1  chinese 根据他的问题i*f[i]我们容易联想到,答案其实是每种方案中每个点的贡献为1的加和 我们可以转变问题,每个点在所有方案的贡献 进而其实询问就是1-k的取值,有多少中方案再取个和 ...

  5. 【模拟7.29】大佬(概率期望DP)

    首先根据数据范围,可以判断基本上是n^2的复杂度 通过分析我们发现每一次都可以从m个数中任意选,既然任意选,那么此时的概率的分母就是不变的,然而题中涉及的是某一段的最大值,所以我们按套路假设 f[i] ...

  6. Cheatsheet: 2016 02.01 ~ 02.29

    Web How to do distributed locking Writing Next Generation Reusable JavaScript Modules in ECMAScript ...

  7. [jzoj]2505.【NOIP2011模拟7.29】藤原妹红

    Link https://jzoj.net/senior/#main/show/2505 Description 在幻想乡,藤原妹红是拥有不老不死能力的人类.虽然不喜欢与人们交流,妹红仍然保护着误入迷 ...

  8. jzoj2700 【GDKOI2012模拟02.01】数字

    传送门:https://jzoj.net/senior/#main/show/2700 [题目大意] 令n为正整数,S(n)为n的各位数字之和,令

  9. jzoj2701 【GDKOI2012模拟02.01】矩阵

    传送门:https://jzoj.net/senior/#main/show/2701 [题目大意] 给出矩阵A,求矩阵B,使得

随机推荐

  1. Haploid inheritance|Hardy-Weinberg proportions|

    I.2 Haploid inheritance 单倍体也有短暂的二倍体时期: Meiosis:减数分裂 依据图示信息,同时基因型A的频率是p,基因型a的频率是(1-p): 建立Hardy-Weinbe ...

  2. log4j中%5p的含义

    因为日志级别分别有error,warn,info,debug,fatal5种,有些是5个字母的,有些是4个字母的,如果直接写%p就会对不齐,%-5p的意思是日志级别输出左对齐,右边以空格填充,%5p的 ...

  3. overflow text-overflow 超过部分隐藏问题

    overflow:是针对容器内所有的数据溢出的一种统一处理方式,不管容器内的存储的是文本 图片还是其他的数据 统一取值; hidden隐藏, scroll滚动条显示,visible溢出显示text-o ...

  4. 非IoC方式访问Servlet API的两种方法

    使用ActionContext访问 ActionContext来自com.opensymphony.xwork2.ActionContext 具体实现代码段如下: <span style=&qu ...

  5. 《C Prime Plus》第十节笔记

    数组和指针 10.1 数组 10.1.1 初始化数组 标量变量:只储存单个值的变量 创建只读数组,应该用const声明和初始化数组 const int days[] = {1,2,3,5}; 省略方括 ...

  6. hdu5452

    http://acm.hdu.edu.cn/showproblem.php?pid=5452 题意:给个图T(图G的最小生成树),然后再给定图G的剩余边,问你从图T中当且割一条边的情况再割图G中不属于 ...

  7. Python||NameError: name 'reload' is not defined

    多半是运行如下代码时报错: import sysreload(sys)sys.setdefaultencoding("utf-8")123这段代码是为了解决Python中中文输出出 ...

  8. python学习笔记(8)迭代器和生成器

    迭代器 迭代是Python最强大的功能之一,是访问集合元素的一种方式. 迭代器是一个可以记住遍历的位置的对象. 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束.迭代器只能往前不会后退 ...

  9. 隐藏windows7/8“卸载或更改程序”里的软件

    隐藏windows7/8“卸载或更改程序”里的软件 通过修改注册表即可隐藏电脑中已安装的软件,这个方法会造成卸载列表无法加载已安装的软件,请谨慎操作!提示:删除注册表后windows自带的卸载程序.其 ...

  10. jenkins使用(2)-配置项目代码的3种方式

    1.通过cmd命令直接进入项目代码的文件夹运行,注意路径中不要有中文 2.代码放到工作区:从本地复制项目代码到工作区目录下 代码结构的优化 3.代码连接git或svn,实时更新代码 svn检出 然后上 ...