题解 | #暴力出奇迹#

暴力出奇迹

https://ac.nowcoder.com/acm/problem/19437

暴力枚举最高位,将其分成数个子序列,各个子序列分别计算最大值 代码

void solve(){
int n;
    cin >> n;
    for (int i = 1; i <= n; i++)
        cin >> a[i];
 
    ll ans = 0;
    for (int i = 0; i <= 21; i++) {
        ll sum = 0, tmp = (1 << (21)) - 1;
        for (int j = 1; j <= n; j++) {
            if (a[j] >> i & 1) {
                sum += a[j];
                tmp &= a[j];
                ans = max(ans, sum * tmp);
            } else {
                sum = 0;
                tmp = (1 << (21)) - 1;
            }
        }
    }
    cout << ans << endl;
}
全部评论

相关推荐

07-10 14:08
已编辑
江西农业大学 Java
点赞 评论 收藏
分享
大疆在线测评都考什么呀,会考企业概况啥的吗
又被画饼了的做题家很...:不会。刚做完,就是材料分析、态度题、算术题、逻辑题。总共60道。
投递大疆等公司7个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务