蓝桥杯刷题日记03-好数

问题描述

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

给定一个正整数 NN,请计算从 1 到 NN 一共有多少个好数。

输入格式

一个整数 NN。

输出格式

一个整数代表答案。

样例输入 1

复制代码
24

样例输出 1

复制代码
7

样例输入 2

复制代码
2024

样例输出 2

复制代码
150

样例说明

对于第一个样例,2424 以内的好数有 11、33、55、77、99、2121、2323,一共 77 个。

评测用例规模与约定

对于 10%10% 的评测用例,1≤N≤1001≤N≤100 。

对于 100%100% 的评测用例,1≤N≤1071≤N≤107 。

运行限制

语言 最大运行时间 最大运行内存
C++ 1s 256M
C 1s 256M
Java 3s 512M
Python3 10s 512M
PyPy3 3s 512M
Go 5s 512M
JavaScript 5s 512M

思路

for循环 if 判断 直接暴力就完了

复制代码
#include <stdio.h>
#include <stdlib.h>
int main(int argc, char *argv[])
{
  long long n;
  long long ans=0;
  scanf("%lld",&n);
  for(;n>=1;n--){
    int i=1;
    for(long long m=n;m>0;){
      if(i==1){
        if(m%2!=0){
          m=m/10;
          i=2;
        }
        else{
          i=2;
          break;
        }
      }
      if(i==2){
        if(m%2==0){
          m=m/10;
          i=1;
        }
        else{
          i=1;
          break;
        }
      }
      if(m==0){
        ans++;
      }
    }
  }
  printf("%lld",ans);
  return 0;
}
相关推荐
松☆几秒前
C++ 程序设计基础:从 Hello World 到数据类型与 I/O 流的深度解析
c++·算法
今儿敲了吗4 分钟前
41| 快速乘
数据结构·c++·笔记·学习·算法
愚者游世5 分钟前
alignof 和 alignas各版本异同
c++·学习·程序人生·职场和发展·visual studio
一行17 分钟前
旧电脑重生:老i5装Ubuntu 保姆级步骤
服务器·windows·学习
ysa0510307 分钟前
树的定向(dfs并查集贪心)
数据结构·c++·笔记·算法·深度优先·图论
卡梅德生物科技7 分钟前
卡梅德生物科普:CD140a(PDGFRα)靶点深度解析:机制、药物研发与未来趋势
大数据·人工智能·面试·职场和发展·学习方法
bkspiderx31 分钟前
MQTT 开源库:Eclipse Paho C 详解,特性、交叉编译与实战示例
c语言·mqtt·开源·eclipse paho c
mjhcsp31 分钟前
C++ A* 算法:启发式路径搜索的黄金标准
android·c++·算法
djarmy40 分钟前
量子计算必然走向边缘+终端+云端的分布式架构,而oh是目前唯一面向全场景的分布式
c语言
仰泳的熊猫1 小时前
题目2281:蓝桥杯2018年第九届真题-次数差
数据结构·c++·算法·蓝桥杯