Loading [MathJax]/jax/output/CommonHTML/fonts/TeX/fontdata.js
星星之火

[雅礼NOIP2018集训 day1]

现在才来填坑,之后还要陆续补其他几天的,可能前几天真的太颓了


T1:

题目大意:给定一个长度为n的序列,m次询问每次询问给出l,r,询问区间l到r的元素在模k意义下的最大值

数据范围当然是你暴力写不过的...

老实说我考场敲了主席树,不幸的是只拿到了暴力的分

考虑正解?我们分块。预处理出每一块在模k意义下的最大值,多余部分暴力计算就好

上面一句话显然是废话,我么怎么预处理出每一块在模任意k意义下的最大值呢?

显然在[ak,(a+1)k)这一段值域中,数值最大值一定是最优的,我们可以开个表记录当前块中小于等于当前数字的最大的元素的大小,预处理统计一段的答案时就是取小于等于(a+1)k1的最大值就好了

发现[ak,(a+1)k)的区间一共有klnk个,其实我也不知道怎么得到的,这样时间复杂度好像就对了,实测卡过去是比较轻松的

复制代码
#include<algorithm>
#include<cstring>
#include<cstdio>
#include<iostream>
using namespace std;

const int N=1e5;
const int M=1e2;
int n,m;
int a[N+5],lst[N+5],ans[M][N+5];
inline int read()
{
    char ch=getchar();
    int s=0,f=1;
    while (ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=getchar();}
    while (ch>='0'&&ch<='9') {s=(s<<3)+(s<<1)+ch-'0';ch=getchar();}
    return s*f;
}
int main()
{
//    freopen("flower.in","r",stdin);
//    freopen("flower.out","w",stdout);
    int B=1000;
    n=read();m=read();
    for (int i=1;i<=n;i++) a[i]=read();
    int siz=(n-1)/B;
    for (int i=0;i<=siz;i++)
    {
        memset(lst,0,sizeof(lst));
        int l=i*B+1,r=min(n,(i+1)*B);
        for (int j=l;j<=r;j++) lst[a[j]]=a[j];
        for (int j=1;j<=N;j++) lst[j]=max(lst[j],lst[j-1]);
        for (int j=1;j<=N;j++) for (int k=0;k<=N;k+=j) ans[i][j]=max(ans[i][j],lst[min(N,k+j-1)]-k);
    }
    while (m--)
    {
        int l=read(),r=read(),k=read();
        int L=(l-1)/B,R=(r-1)/B,re=0;
        for (int i=L+1;i<R;i++) re=max(re,ans[i][k]);
        for (int i=l;i<=min((L+1)*B,r);i++) re=max(re,a[i]%k);
        for (int i=max(l,R*B+1);i<=r;i++) re=max(re,a[i]%k);
        printf("%d\n",re);
    }
    return 0;
}
View Code
复制代码

T2:

emm这题出题人很坑啊,像笔者这样的蒟蒻在看到条件1的时候就直接按y排序了,出题人的意思是这样不好优化,笔者在考场上好像也许可能大概刚出了时间复杂度正确的前缀和优化,无奈死在了128MB的空间上

正解是按x排序,dpi,0/1表示以第i个点为顶端的向左和向右的方案数。注意到当前点的x值是最大的,那么显然只能在前i个点中只能作为折线的第一个点或第二个点

那么有两种转移方法

dpj,1>dpi,0  yj<yi

dpk,1>dpj,1 yj>yi,yk<yi,xk>xj

以上显然都有xi>xj,xi>xk

发现第二种转移可以前缀和优化一下

复制代码
#include<algorithm>
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
typedef long long ll;

const int N=6e3+15;
const int mod=1e9+7;
int n;
ll dp[N][2];
struct node
{
    ll x,y;
}e[N];
inline ll read()
{
    char ch=getchar();
    ll s=0,f=1;
    while (ch<'0'||ch>'9') {if (ch=='-') f=-1;ch=getchar();}
    while (ch>='0'&&ch<='9') {s=(s<<3)+(s<<1)+ch-'0';ch=getchar();}
    return s*f;
}
bool cmp(node a,node b) {return a.x<b.x;}
int main()
{
    //freopen("refract.in", "r", stdin);
    //freopen("refract.out", "w", stdout);
    n=read();
    for (int i=1;i<=n;i++) {e[i].x=read();e[i].y=read();}
    sort(e+1,e+1+n,cmp);
    for (int i=1;i<=n;i++)
    {    
        dp[i][0]=dp[i][1]=1;
        for (int j=i-1;j>=1;j--) 
            if (e[j].y<e[i].y) (dp[i][0]+=dp[j][1])%=mod;
            else (dp[j][1]+=dp[i][0])%=mod;
    }
    ll ans=mod-n;//dp[i][0]和dp[i][1]算重了 
    for (int i=1;i<=n;i++) (ans+=dp[i][0]+dp[i][1])%=mod;
    printf("%lld\n",ans);
    return 0;
}
View Code
复制代码

T3:

待填

 

posted @   星星之火OIer  阅读(466)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系统下SQL Server数据库镜像配置全流程详解
· 现代计算机视觉入门之:什么是视频
· 你所不知道的 C/C++ 宏知识
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· SQL Server 内存占用高分析
阅读排行:
· DeepSeek V3 两周使用总结
· 回顾我的软件开发经历(1)
· C#使用yield关键字提升迭代性能与效率
· 4. 使用sql查询excel内容
· 低成本高可用方案!Linux系统下SQL Server数据库镜像配置全流程详解
欢迎阅读『[雅礼NOIP2018集训 day1]』
点击右上角即可分享
微信分享提示