蓝桥杯训练题,k进制数,c++语言,codeblocks编译。

题目描述
考虑包含N位数字的K-进制数. 定义一个数有效, 如果其K-进制表示不包含两连续的0.

考虑包含N位数字的K-进制数. 定义一个数有效, 如果其K-进制表示不包含两连续的0.

例:
1010230 是有效的7位数
1000198 无效
0001235 不是7位数, 而是4位数.

给定两个数N和K, 要求计算包含N位数字的有效K-进制数的总数.

假设2 <= K <= 10; 2 <= N; 4 <= N+K <= 18.

输入
两个十进制整数N和K

输出
十进制表示的结果

样例输入
2
10
样例输出
90
题目其实看似很乱,但想清楚其实很简单,这题目是要求数量,但进制数有很多,所以感觉会变得复杂。
思想:一位十进制数的数量0-9有九个,两位十进制数数量0-99有一百个,那么三位就是1000个,这不局限于十进制,其他进制数也有此规律。
有了初步理解,下面做题。
一位十进制数:满足条件的,只有1-9有九个,也就是k-1个,那么不满足条件的只有0,也就是一个。记录:yes1=k-1,no1=1;
两位十进制数:先看十位数,不能出现0,那么有k-1个,再看个位,此刻是可以出现0的,那么有十个,也就是k个,即(k-1+1),这就出来规律了,此刻的yes2=(k-1)*(yes1+no1),这是满足条件的,那么不满足条件的呢?不满足条件的其实无非是当十位是0的时候,那么有十个对吧?但题目有条件,是说不能出现连续的两个0,也就是说,当十位和个位都出现0,也是不满足的,所以该减去一个,那么不满足条件的是九个,也就是k-1,发现了没有?这个k-1是上一个yes1,即,no2=yes1。
那代码无非是很简单了!

#include<bits/stdc++.h>
using namespace std;
int main(){
    int N,k;
    cin>>N>>k;
    int yes=k-1,no=1;
    for(int i=2;i<=N;i++){
        int last_yes=yes;
        yes=(k-1)*(yes+no);
        no=last_yes;
    }
    cout<<yes<<endl;
    return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值