P3293 [SCOI2016]美味

本文详细解析了P3293[SCOI2016]美味问题,通过位运算和区间查询算法求解特定数学表达式的最大值。介绍了如何使用线段树进行区间更新和查询,实现高效求解。

题目

P3293 [SCOI2016]美味

做法

\(l\)~\(r\)中的\(a_i\)使得\((a_i+x)\)^\(b\)的最大值

显然当\((b>>i)\&1\),我们尽量使得这位\(=((b>>i)\&1)\)^\(1\)

初始化\(ans=0\),然后倒序遍历位数,\(ans\)是实时更新的,为还确定这位前的最大值

\(tmp(ans+(((1\&(b>>i))\)^\(1)<<i));\)其中\(tmp\)是我们想要得到的(这位及更高位)值,所以查询\((tmp-x,tmp+(1<<i)-1-x)\)中(满足\(tmp\))是否存在值

My complete code

#include<cstdio>
#include<iostream>
using namespace std;
typedef int LL;
const LL maxn=4000000,inf=0x3f3f3f3f;
inline LL Read(){
    LL x(0),f(1);char c=getchar();
    while(c<'0'||c>'9'){if(c=='-')f=-1;c=getchar();}
    while(c>='0'&&c<='9')x=(x<<3)+(x<<1)+c-'0',c=getchar();
    return x*f;
}
LL n,nod,Mi=inf,Mx=-inf,m;
LL a[maxn],val[maxn],son[maxn][2],root[maxn];
inline void Update(LL &now,LL pre,LL l,LL r,LL c){
    now=++nod;
    val[now]=val[pre]+1;
    if(l==r) 
        return;
    LL mid(l+r>>1);
    if(c<=mid){
        Update(son[now][0],son[pre][0],l,mid,c);
        son[now][1]=son[pre][1];
    }else{
        Update(son[now][1],son[pre][1],mid+1,r,c);
        son[now][0]=son[pre][0];
    }
}
LL Query(LL pre,LL now,LL l,LL r,LL lt,LL rt){
    if(lt<=l&&rt>=r)
        return val[now]-val[pre];
    LL ret(0),mid(l+r>>1);
    if(lt<=mid)
        ret=Query(son[pre][0],son[now][0],l,mid,lt,rt);
    if(rt>mid)
        ret+=Query(son[pre][1],son[now][1],mid+1,r,lt,rt);
    return ret;
}
inline bool Check(LL l,LL r,LL ln,LL rn){
    ln=max(ln,Mi),rn=min(rn,Mx);
    if(rn<ln) return false;
    return Query(root[l-1],root[r],Mi,Mx,ln,rn);
}
int main(){
    n=Read(),m=Read();
    for(LL i=1;i<=n;++i){
        a[i]=Read();
        Mi=min(Mi,a[i]),Mx=max(Mx,a[i]);
    }
    for(LL i=1;i<=n;++i)
        Update(root[i],root[i-1],Mi,Mx,a[i]);
    while(m--){
        LL ans(0),b(Read()),x(Read()),l(Read()),r(Read());
        for(LL i=17;i>=0;--i){
            LL tmp(ans+(((1&(b>>i))^1)<<i));
            if(Check(l,r,tmp-x,tmp+(1<<i)-1-x))
                ans=tmp;
            else
                ans+=((b>>i)&1)<<i;
        }
        printf("%d\n",ans^b);
    }
    return 0;
}

转载于:https://www.cnblogs.com/y2823774827y/p/10306250.html

在车辆工程中,悬架系统的性能评估和优化一直是研究的热点。悬架不仅关乎车辆的乘坐舒适性,还直接影响到车辆的操控性和稳定性。为了深入理解悬架的动态行为,研究人员经常使用“二自由度悬架模型”来简化分析,并运用“传递函数”这一数学工具来描述悬架系统的动态特性。 二自由度悬架模型将复杂的车辆系统简化为两个独立的部分:车轮和车身。这种简化模型能够较准确地模拟出车辆在垂直方向上的运动行为,同时忽略了侧向和纵向的动态影响,这使得工程师能够更加专注于分析与优化与垂直动态相关的性能指标。 传递函数作为控制系统理论中的一种工具,能够描述系统输入和输出之间的关系。在悬架系统中,传递函数特别重要,因为它能够反映出路面不平度如何被悬架系统转化为车内乘员感受到的振动。通过传递函数,我们可以得到一个频率域上的表达式,从中分析出悬架系统的关键动态特性,如系统的振幅衰减特性和共振频率等。 在实际应用中,工程师通过使用MATLAB这类数学软件,建立双质量悬架的数学模型。模型中的参数包括车轮质量、车身质量、弹簧刚度以及阻尼系数等。通过编程求解,工程师可以得到悬架系统的传递函数,并据此绘制出传递函数曲线。这为评估悬架性能提供了一个直观的工具,使工程师能够了解悬架在不同频率激励下的响应情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值