(计数器)NOIP模拟赛(神奇的数位DP题。。)

没有原题传送门。。

手打原题QAQ

【问题描述】

    一本书的页数为N,页码从1开始编起,请你求出全部页码中,用了多少个012,…,9。其中—个页码不含多余的0,如N1234时第5页不是0005,只是5

【输入】

       一个正整数N(N109),表示总的页码。

【输出】

       共十行:第k行为数字k-1的个数。

这道题是一道很有意思的DP题。

我们先来看一看这道题目

就是求1~n这么多个数中有多少个X数字。

然后我们来看一看一个例子:

在1~10这10个数中,每个数字(0~9)都在个位数中出现了1次。

在1~100这100个数中,每个数字(0~9)都在十位数中出现了10次。

在1~1000这1000个数中,每个数字(0~9)都在百位数中出现了100次。

以此类推。

所以我们得出了规律

在1~10^n中,数字x在第n-1位中出现了10^n-1次

如求2516数字5出现的次数

首先在2511~2516中,数字5在个位数出现1次;

在1~2510中,数字5在个位数中出现251次

251+1=252;

在1~2500中,数字5在十位数中出现25*10=250次

在1~2000中,数字5在百位数出现了2*100=200次

但是没完!

在2500~2516这么多数中,数字5在百位数还出现了16+1=17次

因为千位数字为2,小于5,所以5不会出现在千位

所以数字5出现的总次数就是252+250+200+17=719次

所以对于任何一个数字X,计算法则如下

计算X在右数第i位出现的次数

则为:

a=X*10^(i-1);

若num[i]>X return a+10^(i-1)即开头全部都为X数字的

若num[i]<X return a;

若num[i]==x return a+num%(10^i)+1;

但是对于任何一个数,0不可能为首位。

所以在计算0只能计算到第n-1位(假设num的位数为n)

然后判断一下就可以搞出来啦!

#include<iostream>
#include<cstdio>
using namespace std;
int qs,n,l;
long long num[11];
long long tt[11];
long long ans[11];
int main(){
    freopen("count.in","r",stdin);
    freopen("count.out","w",stdout);
    scanf("%d",&n);
    qs=n;
    while(qs){
    l++;
    num[l]=qs%10;
    qs/=10;    
    }
    tt[1]=1;
    for(int i=2;i<=10;i++)
    tt[i]=tt[i-1]*10;
    qs=n;
    for(int i=l;i>=1;i--)
    {
        for(int j=0;j<=9;j++)
        ans[j]+=tt[i-1]*num[i]*(i-1);
        for(int j=0;j<num[i];j++)
        ans[j]+=tt[i];
        ans[num[i]]+=qs%tt[i]+1;
    }
    for(int i=1;i<=l;i++)
    ans[0]-=tt[i];
    for(int i=0;i<=9;i++)
    printf("%lld\n",ans[i]);
    fclose(stdin);
    fclose(stdout);
    return 0;
}

 

转载于:https://www.cnblogs.com/ghostfly233/p/6882459.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
NOI(全国青少年信息学奥林匹克竞模拟的测试数据是指用于评测参选手的程序的输入和对应的输出。测试数据是非常重要的,因为它决定了参选手的程序能否正确地解决问。 在NOI模拟,测试数据具有以下特点: 1.充分覆盖:测试数据应涵盖各种可能的输入情况,包括边界条件和极端情况。通过提供不同的测试数据,可以考察选手对问的全面理解和解决能力。 2.随机性和均衡性:为了公平起见,测试数据应该是随机生成的,而不是针对某个特定算法或解法设计的。同时,测试数据应该是均衡的,即各种情况的概率应该大致相等,以避免偏向某些解法。 3.合理性和可行性:测试数据应该是合理和可行的,即符合目要求的输入数据,并且是选手能够通过编写程序来处理的。测试数据应该考虑到程序的限制和时间复杂度,以充分测试选手的编程能力。 NOI模拟的测试数据通常由经验丰富的考组负责生成。他们会根据目的要求和限制,设计出一组合理、充分、随机和均衡的测试数据,以确保参选手的程序在各种情况下都能正确运行,并且能通过性能测试。 总之,测试数据在NOI模拟起到了至关重要的作用,它既考察了选手对问的理解和解决能力,又提高了选手编程的技巧和效率。同时,合理和恰当的测试数据也是公平竞的保证,确保每个参选手有相同的机会和条件进行竞争。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值