当前位置: 首页 > news >正文

1313:【例3.5】位数问题

【题目描述】

在所有的NN位数中,有多少个数中有偶数个数字3?由于结果可能很大,你只需要输出这个答案对1234512345取余的值。

【输入】

读入一个数N(N≤1000)N(N≤1000)。

【输出】

输出有多少个数中有偶数个数字3。

【输入样例】

2

【输出样例】

73

递推思路
当 N=1,数字范围为 0 ~ 9,合计 9-0+1=10 个。

(1)含有偶数个 3 数字有 9 个(0、1、2、4、5、6、7、8、9)。 

(2)含有奇数个 3 数字有 1 个(3)。

当 N=2,数字范围为 10 ~ 99,合计 99-10+1=90 个。

(1)含有偶数个 3 数字的构成:前面一位数中含有奇数个 3 数字,在其前面加上数字 3 的组合,有 1*1=1个,即数字 33,这样有 1 个数字;前面一位含有偶数个 3 数字(0、1、2、4、5、6、7、8、9),在其前面加上不是 3 的数字(1、2、4、5、6、7、8、9)的组合,有 8*9=72 个。合计 72+1=73。

(2)含有奇数个 3 数字的构成:前面一位数中含有奇数个 3 ,在其前面加上数字为(1、2、4、5、6、7、8、9)的组合,有 8*1=8 个。前面一位数中含有含有偶数个 3 数字(0、1、2、4、5、6、7、8、9),在其前面加上数字为 3 的组合,有 9*1=9 个。合计 8+9=17 个。

当 N=3,数字范围为 100 ~ 999,合计 999-100+1=900 个。

(1)含有偶数个 3 数字的构成:前面两位数字中含有奇数个 3(有 1*9+9*1 个,即18个,注意这个时候数字 0 可以放在前头,因为百位我们还能加数字),在其前面加上数字 3 的组合,合计 18*1=18 个;前面两位数字中含有偶数个 3(有 9*9+1*1 个,即82个,注意这个时候数字 0 可以放在前头,因为百位我们还能加数字) ,数字前加上不是 3 的数字(1、2、4、5、6、7、8、9),有 82*8=656。合计有 18+656=674 个。

(2)含有奇数个 3 数字的构成:前面两位数字中含有奇数个 3(有 1*9+9*1 个,即18个,注意这个时候数字 0 可以放在前头,因为百位我们还能加数字),在其前面加上不是 3 的数字(1、2、4、5、6、7、8、9)的组合,合计 18*8=144 个;前面两位数字中含有偶数个 3(有 9*9+1*1 个,即82个,注意这个时候数字 0 可以放在前头,因为百位我们还能加数字) ,数字前加上数字 3,有 82*1=82。合计有 144+82=226 个。

以此类推。这样我们就可以推倒出如下的递推公式:

N 表示位数,a[i] 表示到第 i 位包含偶数个 3 的数字数量,b[i] 表示到第 i 位包含奇数个 3 的数字数量
a[1] = 9                              b[1] = 1
当 i<N 的时候
a[i] = a[i-1]*9 + b[i-1]*1            b[i] = a[i-1]*1 + b[i-1]*9
当 i==N 的时候,由于首位不能为零
a[i] = a[i-1]*8 + b[i-1]*1            b[i] = a[i-1]*1 + b[i-1]*8

代码搁这里呢

#include<bits/stdc++.h>
using namespace std;
const int Max=1e3+2;
unsigned long long a[Max];
unsigned long long b[Max];
int main()
{
	int n;
	cin>>n;
	int k=9;
	a[1]=9;
	b[1]=1;
	for(int i=2; i<=n; i++)
	{
		if(i==n) k=8;
		a[i]=(a[i-1]*k+b[i-1])%12345;
		b[i]=(a[i-1]+b[i-1]*k)%12345;
	}
	cout<<a[n];
	return 0;
}

此代码仅供参考,请勿纯抄 

相关文章:

  • LabVIEW无人机飞行状态监测系统
  • 【设计模式】【行为型模式】中介者模式(Mediator)
  • 基于单片机的智能奶茶机(论文+源码+图纸)
  • MySQL-数据库查询进阶
  • GPT-SWARM和AgentVerse的拓扑结构和交互机制
  • 在vscode中拉取gitee里的项目并运行
  • springboot021校园周边美食探索及分享平台
  • 湖仓分析|浙江霖梓基于 Doris + Paimon 打造实时/离线一体化湖仓架构
  • React进阶之React核心源码解析(二)
  • 打开Visual Studio Code的时候发现未检测到适用于linux的windows子系统,那么该问题要如何解决?
  • WPS或word接入智能AI
  • Docker 常用命令基础详解(二)
  • Arduino 第十六章:pir红外人体传感器练习
  • Vue3(3)
  • ES的java操作
  • 【第1章:深度学习概览——1.2 深度学习与机器学习、传统人工智能的区别与联系】
  • WEB攻防-第60天:PHP反序列化POP链构造魔术方法流程漏洞触发条件属性修改
  • 第41天:Web开发-JS应用微信小程序源码架构编译预览逆向调试嵌套资产代码审计
  • 自学人工智能大模型,满足7B模型的训练和微调以及推理,预算3万,如何选购电脑
  • Linux初始化 配置yum源
  • 沈阳卫健委通报“健康证”办理乱象:涉事医院已被立案查处
  • 媒体和打拐志愿者暗访长沙一地下代孕实验室,警方已控制涉案人员
  • 傅利叶提出下个十年战略,CEO顾捷:机器人要有温度,要用实际价值来定义形态
  • 宇树科技王兴兴:第一桶金来自上海,欢迎上海的年轻人加入
  • 网络主播直播泄机密,别让这些“小事”成威胁国家安全的“突破口”
  • 巴基斯坦军方:印度导弹袭击巴首都附近空军基地