小O的数位翻转

小O的数位翻转

https://www.nowcoder.com/practice/80a2e1aa90a24841bb153d14f13aa24a

小O的数位翻转

[题目链接](https://www.nowcoder.com/practice/80a2e1aa90a24841bb153d14f13aa24a)

思路

对数组中的每个数字,将其二进制表示翻转(去除前导零),如果翻转后的值严格大于原值,则计入答案。

二进制翻转

对于一个正整数 ,将其二进制从低位到高位逐位取出,依次拼到结果 的低位。具体做法:每次取 的最低位追加到 ,然后 右移一位,直到 为 0。这样自然去除了前导零。

例如 ,翻转后得 ,计入答案。

,翻转后得 ,不计入。

判断条件

翻转后值严格大于原值,等价于二进制的最低位为 1(否则翻转后位数变少,不可能更大)且翻转后确实更大。直接比较即可,无需额外优化。

时间复杂度 ,其中 为数值上界。

代码

#include <bits/stdc++.h>
using namespace std;
int main() {
    int n;
    scanf("%d", &n);
    int ans = 0;
    for (int i = 0; i < n; i++) {
        long long x;
        scanf("%lld", &x);
        long long rev = 0, tmp = x;
        while (tmp > 0) {
            rev = (rev << 1) | (tmp & 1);
            tmp >>= 1;
        }
        if (rev > x) ans++;
    }
    printf("%d\n", ans);
    return 0;
}
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int ans = 0;
        for (int i = 0; i < n; i++) {
            long x = sc.nextLong();
            long rev = 0, tmp = x;
            while (tmp > 0) {
                rev = (rev << 1) | (tmp & 1);
                tmp >>= 1;
            }
            if (rev > x) ans++;
        }
        System.out.println(ans);
    }
}
全部评论

相关推荐

02-25 13:02
中南大学 C++
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
正在热议
更多
# 一张图晒出你司的标语 #
4477次浏览 78人参与
# 找AI工作可以去哪些公司? #
10212次浏览 325人参与
# 厦门银行科技岗值不值得投 #
8266次浏览 188人参与
# 你的实习产出是真实的还是包装的? #
20964次浏览 346人参与
# 从事AI岗需要掌握哪些技术栈? #
9906次浏览 400人参与
# 春招至今,你的战绩如何? #
68165次浏览 603人参与
# 开放七大实习专项,百度暑期实习值得冲吗 #
15784次浏览 230人参与
# AI面会问哪些问题? #
29257次浏览 641人参与
# 你做过最难的笔试是哪家公司 #
36267次浏览 322人参与
# 中国电信笔试 #
32411次浏览 302人参与
# 金三银四,你的春招进行到哪个阶段了? #
22601次浏览 284人参与
# 投递几十家公司,到现在0offer,大家都一样吗 #
341267次浏览 2176人参与
# 同bg的你秋招战况如何? #
212268次浏览 1121人参与
# 哪些公司真双非友好? #
69844次浏览 289人参与
# 如何准备秋招 #
78326次浏览 868人参与
# 阿里笔试 #
179528次浏览 1324人参与
# 应届生被毁约被毁意向了怎么办 #
63364次浏览 305人参与
# 机械人避雷的岗位/公司 #
62728次浏览 393人参与
# 小马智行求职进展汇总 #
25151次浏览 80人参与
# 第一份工作一定要去大厂吗 #
15303次浏览 129人参与
# 担心入职之后被发现很菜怎么办 #
291438次浏览 1210人参与
# 为了减少AI幻觉,你注入过哪些设定? #
26336次浏览 310人参与
牛客网
牛客网在线编程
牛客网题解
牛客企业服务