noip12
T1
类似于昨天的t3,先用单调栈求出管控区间,然后暴力求解30pts
我没取模还没开longlong,然后就爆0了
正解:
- 仍然是用单调栈求一下区间,用线段树维护一下余数,对于i所对应的区间\([l_{i},r_{i}]\) ,当然是去枚举离i近的,剩下的用线段树求解,线段树要用动态开点,不然空间会炸。
Code
#include<cstdio>
#define K 1000010
#define MAX 300010
#define re register
#define int long long
namespace OMA
{
int n,k,ans;
int a[MAX],sum[MAX];
int root[K];
int top,L[MAX],R[MAX],sta[MAX];
struct Segmnet_Tree
{
int tot;
struct TREE
{
int res;
int ls,rs;
}st[K*50];
inline void Push_up(int p)
{ st[p].res = st[st[p].ls].res+st[st[p].rs].res; }
inline void insert(int &p,int l,int r,int pos)
{
p = (!p)?++tot:p;
if(l==r)
{ st[p].res = 1; return ; }
int mid = (l+r)>>1;
if(pos<=mid)
{ insert(st[p].ls,l,mid,pos); }
else
{ insert(st[p].rs,mid+1,r,pos); }
Push_up(p);
}
inline int query(int p,int l,int r,int lp,int rp)
{
if(l<=lp&&rp<=r)
{ return st[p].res; }
int sum = 0,mid = (lp+rp)>>1;
if(l<=mid)
{ sum += query(st[p].ls,l,r,lp,mid); }
if(r>mid)
{ sum += query(st[p].rs,l,r,mid+1,rp); }
return sum;
}
}Tree;
inline int read()
{
int s=0,w=1; char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')w=-1; ch=getchar(); }
while(ch>='0'&&ch<='9'){ s=s*10+ch-'0'; ch=getchar(); }
return s*w;
}
inline void STACK()
{
for(re int i=1; i<=n; i++)
{
while(top&&a[sta[top]]<=a[i])
{ R[sta[top--]] = i-1; }
L[i] = sta[top]+1;
sta[++top] = i;
}
while(top)
{ R[sta[top--]] = n; }
}
signed main()
{
n = read(),k = read();
for(re int i=1; i<=n; i++)
{ (sum[i] = sum[i-1]+(a[i] = read())%k) %= k; }
STACK();
for(re int i=1; i<=n; i++)
{ a[i] %= k; Tree.insert(root[sum[i]],1,n,i); }
for(re int i=1; i<=n; i++)
{
if(L[i]==R[i])
{ continue ; }
if(R[i]-i<i-L[i])
{
for(re int j=i+1; j<=R[i]; j++)
{
if(L[i]-1)
{ ans += Tree.query(root[(sum[j]-a[i]+k)%k],L[i]-1,i-1,1,n); }
else
{
int temp = (sum[j]-a[i]+k)%k;
ans += Tree.query(root[temp],L[i],i-1,1,n);
if(!temp)
{ ans++; }
}
}
if(L[i]-1)
{ ans += Tree.query(root[sum[i-1]],L[i]-1,i-2,1,n); }
else
{
if(i-2)
{ ans += Tree.query(root[sum[i-1]],1,i-2,1,n); }
if(!sum[i-1])
{ ans++; }
}
}
else
{
for(re int j=L[i]; j<=i-1; j++)
{ ans += Tree.query(root[(sum[j-1]+a[i])%k],i,R[i],1,n); }
if(i<R[i])
{ ans += Tree.query(root[sum[i]],i+1,R[i],1,n); }
}
}
printf("%lld\n",ans);
return 0;
}
}
signed main()
{ return OMA::main();}
T2
式子很好推,结果被我一顿乱搞+瞎取模取成了10pts。
首先正难则反(来自数学课),可以先求出变量互不相同时的式子
\]
然后我就码了个快速幂,求阶乘逆元gcd,一顿乱搞30pts->10pts
此时,我自己造了几个数据,发现显然不对,于是去想如何改一下。没想出来,交了个10pts。
正解:
推出式子后,考虑约分,发现只能约2及其倍数。所以去找有多少个2。
然后有个定理 \(2^{n}-a\)和\(a\) 这俩东西中,2的个数是相等的,所以找分子中2的个数,就转换成了去找 \((m-1)!\) 中2的个数,这个可以 \(O(logm)\) 求解。
对于\(m>mod\) 此时一定有一个数为mod的倍数,所以分子为0,但答案并非这个,因是%mod意义下的0,所以直接去计算分母就好了。
\(m\le mod\) 的话,直接暴力计算就好了。
Code
#include<cstdio>
#define MAX 1000100
#define re register
#define int long long
namespace OMA
{
int n,m,a,b;
int inv,c,cnt=63;
const int p = 1e6+3;
inline int quickpow(int a,int b)
{
int ans = 1;
while(b)
{
if(b&1)
{ ans = ans*a; }
a = a*a;
b >>= 1;
}
return ans;
}
signed main()
{
scanf("%lld%lld",&n,&m);
n %= p-1;
int tmp1 = 1,tmp2 = 0;
while(cnt--)
{ tmp1 <<= 1; if(tmp1>=m){ break; } (tmp2 += (m-1)/tmp1) %= p-1; }
c = quickpow(2,n),inv = quickpow(quickpow(2,tmp2),p-2);
b = quickpow(c,(m-1)%(p-1))*inv%p;
if(m<=p)
{
a = inv;
for(re int i=1; i<=m; i++)
{ (a *= c-i) %= p; }
a = ((b-a)%p+p)%p;
printf("%lld %lld\n",a,b);
}
else
{ printf("%lld %lld\n",b,b); }
return 0;
}
}
signed main()
{ return OMA::main(); }
T3
考试的时候写了个f**k大模拟+贪心,还过了自己造的hack数据,结果程序输出全是-1 10pts好成绩
考试做法错误是显然的,比如1 0 0 0 1,我的码会输出-1,因为是从前往后扫,出现次数超过1就换下一个值,顾前不顾后,wa也正常。
正解:
我们可以设二元组(a,b),表示当前位置上的数为a,其连续的长度为b。分别设两个 \(up\)和\(down\),up为能填的最大值,down为最小值,求up应该尽量往上,down相反。
最大值即为 \(up[n].a\),序列倒着就能求出来。具体实现见code。
Code
#include<cstdio>
#define MAX 200010
#define re register
namespace OMA
{
int n,m,cnt[MAX];
int a[MAX],ans[MAX];
struct pair
{ int a,b; };
pair up[MAX],down[MAX];
inline int read()
{
int s=0,w=1; char ch=getchar();
while(ch<'0'||ch>'9'){ if(ch=='-')w=-1; ch=getchar(); }
while(ch>='0'&&ch<='9'){ s=s*10+ch-'0'; ch=getchar(); }
return s*w;
}
inline int min(int a,int b)
{ return a<b?a:b; }
signed LZk()
{
n = read();
for(re int i=1; i<=n; i++)
{ a[i] = read(); }
a[1] = 1;
up[1] = down[1] = (pair){1,1};
for(re int i=2; i<=n; i++)
{
up[i] = (pair){up[i-1].a,up[i-1].b+1};
down[i] = (pair){down[i-1].a,down[i-1].b+1};
if(up[i].b>2)
{ up[i] = (pair){up[i].a+1,1}; }
if(down[i].b>5)
{ down[i] = (pair){down[i].a+1,1}; }
if(a[i])
{
if(up[i].a>a[i])
{ up[i] = (pair){a[i],2}; }
if(down[i].a<a[i])
{ down[i] = (pair){a[i],1}; }
if(up[i].a<a[i]||a[i]<down[i].a)
{ printf("-1\n"); return 0; }
}
}
if(up[n].b==1)
{ up[n] = (pair){up[n-1].a,up[n-1].b+1}; }
printf("%d\n",up[n].a);
a[n] = up[n].a,cnt[up[n].a]++;
for(re int i=n-1; i>=1; i--)
{
if(!a[i])
{
int tmp = min(a[i+1],up[i].a);
if(cnt[tmp]==5)
{ tmp--; }
a[i] = tmp;
}
cnt[a[i]]++;
}
for(re int i=1; i<=n; i++)
{ printf("%d ",a[i]); }
return 0;
}
}
signed main()
{ return OMA::LZk(); }
noip12的更多相关文章
- 20210712 noip12
考场 第一次和 hzoi 联考,成功给 sdfz 丢人 尝试戴耳罩,发现太紧了... 决定改变策略,先用1h看题,想完3题再写. T1 一下想到枚举最大值,单调栈求出每个点能作为最大值的区间,然后以这 ...
随机推荐
- SwaggerHub 更快,标准化的API设计软件
更快,标准化的API设计 在功能强大且直观的编辑器中设计API,该编辑器旨在提高速度和效率,而不会损失设计一致性. SwaggerHub帮助我们简化了设计和实现API的方式-作为一名架构师,我喜欢良好 ...
- lua环境搭建
前言: Linux & Mac上安装 Lua 安装非常简单,只需要下载源码包并在终端解压编译即可,本文介绍Linux 系统上,lua5.3.0版本安装步骤: ↓ 1. Linux 系统上安装 ...
- SpringBoot默认首页跳转设置
大家在使用SpringBoot时候会遇到将系统接口入门设置为"/",那么这个就是我们常见的默认首页跳转的设置.解决的方式有两种 第一种方式:controller里添加一个" ...
- java并发编程基础—生命周期与线程控制
一.线程生命周期 线程被创建启动以后,他既不是一启动就进入执行状态,也不是一直处于执行状态,在线程的生命周期中,它要经过新建(New).就绪(Runnable).运行(Running).阻塞(Bloc ...
- IO编程之对象序列化
对象序列化的目标是将对象保存在磁盘中或者允许在网络中直接传输对象.对象序列化机制循序把内存中的java对象转换成平台无关的二进制流,从而允许把这种二进制流持久的保存在磁盘上,通过网络将这种二进制流传输 ...
- 三分钟入门 InnoDB 存储引擎中的表锁和行锁
各位对 "锁" 这个概念应该都不是很陌生吧,Java 语言中就提供了两种锁:内置的 synchronized 锁和 Lock 接口,使用锁的目的就是管理对共享资源的并发访问,保证数 ...
- LinuxMint 19/Ubuntu 19.10重置开始菜单以及任务栏
====================== 问题:任务栏以及开始菜单弄不见了 解决方法: 快捷键打开终端,输入重置命令: dconf reset -f /
- Java 给Word添加印章
一.概述 本文以Java程序代码展示如何给Word文档添加印章,这里添加的印章为.png格式的图片,添加印章即在Word中的指定位置添加印章图片. 基本思路:加载word文档,获取段落,在段落中插入图 ...
- 当vue 页面加载数据时显示 加载loading
参考:https://www.jianshu.com/p/104bbb01b222 Vue 页面加载数据之前增加 `loading` 动画 创建组件 1.新建 .vue 文件: src -> c ...
- linux系统下操作mysql数据库常见命令
一. 备份数据库(如: test): ①可直接进入后台即可.(MySQL的默认目录:/var/lib/mysql ) ②输入命令: [root@obj mysql]# mysqldump -u roo ...