蓝桥杯历届真题--#好数,简单模拟(C++,Java)

文章目录


题目解读

原题连接

一个整数如果按从低位到高位的顺序,奇数位(个位、百位、万位......)上的数字是奇数,偶数位(十位、千位、十万位......)上的数字是偶数,我们就称之为"好数"。

思路

可以利用奇数位上的数字是奇数,偶数位上的数字是偶数来进行判定

定义变量来记录当前位,奇数位是奇数,奇数位上的数字也是奇数,其%2运算的值应该是相同的

对于偶数位同样成立

完整代码

cpp 复制代码
#include<bits/stdc++.h>

using namespace std;

bool check(int n){
    //当前位数
    int idx=1;
    while(n){
        //取最后一位
        int num=n%10;
        if(idx % 2 != num%2)break;
        idx++;
        n/=10;
    }

    return !n;
}

int main(){
    int n;
    scanf("%d",&n);
    
    int res=0;
    for(int i=1; i<=n; i++){
        if(check(i))res++;
    }

    printf("%d",res);
}
java 复制代码
import java.util.*;

class Main{
    static Scanner sc =new Scanner(System.in);

    public static void main(String args[]) {
        int n=sc.nextInt();
        
        int res=0;
        for(int i=1; i<=n; i++){
            if(check(i))res++;
        }
        
        System.out.println(res);
    }

    static boolean check(int n){
        int idx=1;
        while(n>0){
            int num=n%10;
            if(idx%2 != num%2)break;

            idx++;
            n/=10;
        }
        if(n>0)return false;
        return true;
    }
}

参考

Acwing


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

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

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


相关推荐
跟着珅聪学java2 小时前
JavaScript 底层原理
java·开发语言
Z1Jxxx2 小时前
反序数反序数
数据结构·c++·算法
Mr. Cao code2 小时前
Docker数据管理:持久化存储最佳实践
java·docker·容器
强子感冒了2 小时前
Java 学习笔记:File类核心API详解与使用指南
java·笔记·学习
spencer_tseng2 小时前
eclipse ALT+SHIFT+A
java·ide·eclipse
vyuvyucd2 小时前
C++排序算法全解析
java·数据结构·算法
xlq223222 小时前
37.智能指针
c++
BD_Marathon2 小时前
SpringBoot程序快速启动
java·spring boot·后端
stillaliveQEJ2 小时前
【JavaEE】Spring IoC(二)
java·开发语言·spring
REDcker2 小时前
AIGCJson 库解析行为与异常处理指南
c++·json·aigc·c