首页 最新 热门 推荐

  • 首页
  • 最新
  • 热门
  • 推荐

蓝桥杯历届真题 # 数字诗意(C++,Java)

  • 25-02-20 14:20
  • 3147
  • 5992
blog.csdn.net

文章目录

  • 题目解读
  • [蓝桥杯 2024 省 C] 数字诗意
    • 题目描述
    • 输入格式
    • 输出格式
    • 样例 #1
      • 样例输入 #1
      • 样例输出 #1
    • 提示
  • 思路
  • 完整代码


题目解读

原题链接

[蓝桥杯 2024 省 C] 数字诗意

题目描述

在诗人的眼中,数字是生活的韵律,也是诗意的表达。

小蓝,当代顶级诗人与数学家,被赋予了“数学诗人” 的美誉。他擅长将冰冷的数字与抽象的诗意相融合,并用优雅的文字将数学之美展现于纸上。

某日,小蓝静坐书桌前,目光所及,展现着 n n n 个数字,它们依次为 a 1 , a 2 , ⋯   , a n a_1, a_2, \cdots, a_n a1​,a2​,⋯,an​,熠熠生辉。小蓝悟到,如果一个数能够以若干个(至少两个)连续的正整数相加表示,那么它就蕴含诗意。例如,数字 6 6 6 就蕴含诗意,因为
它可以表示为 1 + 2 + 3 1 + 2 + 3 1+2+3。而 8 8 8 则缺乏诗意,因为它无法用连续的正整数相加表示。

小蓝希望他面前的所有数字都蕴含诗意,为此,他决定从这 n n n 个数字中删除一部分。请问,小蓝需要删除多少个数字,才能使剩下的数字全部蕴含诗意?

输入格式

输入的第一行包含一个整数 n n n,表示展示的数字个数。

第二行包含 n n n 个整数 a 1 , a 2 , ⋯   , a n a_1, a_2, \cdots, a_n a1​,a2​,⋯,an​,相邻整数之间使用一个空格分隔,表示展示的数字。

输出格式

输出一行包含一个整数,表示小蓝需要删除的数字个数,以使剩下的数字全部蕴含诗意。

样例 #1

样例输入 #1

3
3 6 8
  • 1
  • 2

样例输出 #1

1
  • 1

提示

【样例说明】

在样例中,数字 3 3 3 可以表示为 1 + 2 1 + 2 1+2,数字 6 6 6 可以表示为 1 + 2 + 3 1 + 2 + 3 1+2+3,数字 8 8 8 无法表示为连续的正整数相加,因此,需要删除的数字个数为 1 1 1。

【评测用例规模与约定】

对于 30 % 30\% 30% 的评测用例, 1 ≤ n ≤ 1 0 3 1 \le n \le 10^3 1≤n≤103, 1 ≤ a i ≤ 1 0 3 1 \le a_i \le 10^3 1≤ai​≤103。
对于所有评测用例, 1 ≤ n ≤ 2 × 1 0 5 1 \le n \le 2 \times 10^5 1≤n≤2×105, 1 ≤ a i ≤ 1 0 16 1 \le a_i \le 10^{16} 1≤ai​≤1016。

思路

观察管理发现,只有2的次方不满足要求
转化为二进制表示,该数字中只有1个1的数字不满足要求
因此题目转化为把数字转为二进制后求起1的个数
若1的个数为1那么就不满足要求

完整代码

#include

using namespace std;

//num的二进制表示中若只有1个1,那么肯定是2的次方
bool check(long long num){
    int cnt=0;
    while(num){
        int left=num%2;
        if(left)cnt++;
        num/=2;
    }
    if(cnt==1)return true;
    else return false;
}

int main(){
    int res=0;
    int n;
    cin>>n;
    while(n--){
        long long num;
        cin>>num;
        if(check(num))res++;
    }
    
    cout<<res;
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
import java.util.Scanner;

class Main{
    static Scanner sc =new Scanner(System.in);
    static int res;
    public static void main(String[] args) {
        int n=sc.nextInt();

        while(n-->0){
            long num=sc.nextLong();
            if(check(num))res++;
        }

        System.out.println(res);
    }

    static boolean check(long num){
        int cnt=0;
        while(num>0){
            long left=num%2;
            if(left>0)cnt++;
            num/=2;
        }
        if(cnt==1)return true;
        else return false;
    }
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27

?编写本篇文章目的是笔者想以输出的形式进行学习,顺便记录学习点滴?

? 如果本篇文章对你有帮助的话那就点个赞吧??

? 本篇文章可能存在多处不足,如有修改意见,可以私信或者评论我哦 ?


在这里插入图片描述

注:本文转载自blog.csdn.net的旧物有情的文章"https://blog.csdn.net/mzh1213/article/details/145062763"。版权归原作者所有,此博客不拥有其著作权,亦不承担相应法律责任。如有侵权,请联系我们删除。
复制链接
复制链接
相关推荐
发表评论
登录后才能发表评论和回复 注册

/ 登录

评论记录:

未查询到任何数据!
回复评论:

分类栏目

后端 (14832) 前端 (14280) 移动开发 (3760) 编程语言 (3851) Java (3904) Python (3298) 人工智能 (10119) AIGC (2810) 大数据 (3499) 数据库 (3945) 数据结构与算法 (3757) 音视频 (2669) 云原生 (3145) 云平台 (2965) 前沿技术 (2993) 开源 (2160) 小程序 (2860) 运维 (2533) 服务器 (2698) 操作系统 (2325) 硬件开发 (2492) 嵌入式 (2955) 微软技术 (2769) 软件工程 (2056) 测试 (2865) 网络空间安全 (2948) 网络与通信 (2797) 用户体验设计 (2592) 学习和成长 (2593) 搜索 (2744) 开发工具 (7108) 游戏 (2829) HarmonyOS (2935) 区块链 (2782) 数学 (3112) 3C硬件 (2759) 资讯 (2909) Android (4709) iOS (1850) 代码人生 (3043) 阅读 (2841)

热门文章

131
学习和成长
关于我们 隐私政策 免责声明 联系我们
Copyright © 2020-2025 蚁人论坛 (iYenn.com) All Rights Reserved.
Scroll to Top