Live2D

Solution -「LOCAL」二进制的世界

Description

  OurOJ.

  给定序列 {an} 和一个二元运算 op{and,or,xor},对于 i[2,n],求出 maxj[1,i){aiopaj} 以及 |argmaxj[1,i){aiopaj}|

  n105ai<216

Solution

  也许算是 Meet in Middle?从左到右在线更新可用的 aj 信息并求出对于当前 i 的答案,维护一个 f(u,v),表示选取的 aj 的高八位是 uai 的低八位是 v 时,低八位能得到的最大值以及方案数。那么更新时,用当前 aj 的低八位更新所有 f(u,i);查询时枚举高八位选择的值 i,并用 f(i,v) 更新答案。最终复杂度为 O(nA)

  确实是比较巧妙的复杂度平衡,也是一个实用的 trick√

Code

/*~Rainybunny~*/

#include <bits/stdc++.h>

#define rep( i, l, r ) for ( int i = l, rep##i = r; i <= rep##i; ++i )
#define per( i, r, l ) for ( int i = r, per##i = l; i >= per##i; --i )

typedef std::pair<int, int> PII;
#define fi first
#define se second

const int MAXN = 1e5, MAXSV = 1 << 8;
int n, a[MAXN + 5];
char op[5];
PII f[MAXSV][MAXSV];

inline void update( const int x, const auto& opt ) {
    int h = x >> 8, l = x ^ h << 8;
    rep ( i, 0, MAXSV - 1 ) {
        int v = opt( i, l );
        if ( f[h][i].fi < v ) f[h][i] = { v, 1 };
        else if ( f[h][i].fi == v ) ++f[h][i].se;
    }
}

inline PII query( const int x, const auto& opt ) {
    int l = x & ( ( 1 << 8 ) - 1 );
    PII ret( 0, 0 );
    rep ( h, 0, MAXSV - 1 ) if ( f[h][l].se ) {
        int cur = opt( h, x >> 8 ) << 8 | f[h][l].fi;
        if ( ret.fi < cur ) ret = { cur, f[h][l].se };
        else if ( ret.fi == cur ) ret.se += f[h][l].se;
    }
    return ret;
}

inline void solve( const auto& opt ) {
    update( a[1], opt );
    rep ( i, 2, n ) {
        PII ans( query( a[i], opt ) );
        printf( "%d %d\n", ans.fi, ans.se ), update( a[i], opt );
    }
}

int main() {
    scanf( "%d %s", &n, op );
    rep ( i, 1, n ) scanf( "%d", &a[i] );
    if ( op[0] == 'x' ) {
        solve( []( const int u, const int v ) { return u ^ v; } );
    } else if ( op[0] == 'a' ) {
        solve( []( const int u, const int v ) { return u & v; } );
    } else {
        solve( []( const int u, const int v ) { return u | v; } );
    }
    return 0;
}

posted @   Rainybunny  阅读(54)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示