LuckyNumber:数位相同至多两位的数

该博客主要介绍了一种算法问题,即找出所有小于等于给定正整数n且数位上数字重复不超过两次的数的个数。博主通过分析不同位数的情况,如1位数、2位数、3位数等,计算出这些幸运数字的数量。例如,不超过103的幸运数字有351个。解决方案涉及到了二进制数组的使用,用于表示不同位上的数字可能情况。
摘要由CSDN通过智能技术生成

给定一个数,要给出小于等于这个数的所有非负数中,各个数位上的数字重复不超过两次的数的个数。

比如111,110,112,121,1211都是,102,120,1200就不是。

★题目描述

YY 的幸运数字是......,是什么数字我也不知道,但是已知这个数字的十进制表示(不含前导零)中只包含不超过两个不同的数字。

给定一个数 nn ,请计算出不超过 nn 的所有正整数中,有可能是 YY 的幸运数字的个数。

★输入

输入一行,包含一个正整数 nn。

对于 60% 的数据:

1≤n≤10的5次方,

对于 100% 的数据:

1≤n≤10的9次方。

★输出

输出一个整数,表示不超过 nn 的所有正整数中,有可能是 YY 的幸运数字的个数。

★输入样例

103

★输出样例

101

★样例解释

不超过103的所有正整数中,只有102、103不可能是 YY 的幸运数字。

代码:

#include<iostream>
#include<stdio.h>
using namespace std;
#define sc scanf
#define ci cin
#define co cout
#define e endl
#define Maxx(a,b) (a>b?a:b)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值