数论 - 简单数位推理 --- NYIST 514

简介: Problem's Link:http://acm.nyist.net/JudgeOnline/problem.php?pid=514   Mean:   给你一个l和r,求出在这个范围内的1的个数。

 

Problem's Link:http://acm.nyist.net/JudgeOnline/problem.php?pid=514


 

Mean: 

 给你一个l和r,求出在这个范围内的1的个数。

analyse:

 简单的数位推理。

Time complexity:O(n) n为数字的位数

 

Source code:

 

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<cstring>
#include<string>
#include<queue>
#include<map>
#include<cstdlib>
#include<stack>
#define N 11
using namespace std;
int d[N];
int value;
void deal(int n)
{
    if(n<=0) return;
    int one,ten;
    one=n%10;
    n/=10;
    ten=n;
    for(int i=0;i<=one;++i)
    {
        d[i]+=value;
    }
    while(ten)
    {
        d[ten%10]+=(one+1)*value;
        ten/=10;
    }
    for(int i=0;i<10;++i)
        d[i]+=value*n;
    d[0]-=value;
    value*=10;
    deal(n-1);
}
int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(0);
    int s,e;
    while(cin>>s>>e,s||e)
    {
        if(s>e)swap(s,e);
        memset(d,0,sizeof d);
        value=1;
        deal(e);
        value=-1;
        deal(s-1);
        cout<<d[1]<<endl;
    }
    return 0;
}

  

目录
相关文章
|
7月前
|
算法 测试技术 C++
【动态规划】【数学】【C++算法】1449. 数位成本和为目标值的最大数字
【动态规划】【数学】【C++算法】1449. 数位成本和为目标值的最大数字
|
7月前
|
算法 Java C++
试题 算法训练 6-2递归求二进制表示位数
试题 算法训练 6-2递归求二进制表示位数
47 0
|
机器学习/深度学习 人工智能 算法
【算法基础】分解质因数
【算法基础】分解质因数
139 0
|
4月前
|
算法
【算法】位运算算法——只出现一次的数字Ⅱ
【算法】位运算算法——只出现一次的数字Ⅱ
|
7月前
|
算法 测试技术 C#
【数学】【数论】【最大公约数】1819. 序列中不同最大公约数的数目
【数学】【数论】【最大公约数】1819. 序列中不同最大公约数的数目
|
存储 算法 Python
信息学奥赛 试除法:高效筛选素数的算法
本文介绍了在Python代码中如何使用试除法高效筛选素数。
136 0
|
7月前
【每日一题Day350】LC2652倍数求和 | 数学+容斥原理
【每日一题Day350】LC2652倍数求和 | 数学+容斥原理
47 0
剑指offer_发散思维---数值的整数次方
剑指offer_发散思维---数值的整数次方
73 0
(博弈)(思维)(试除法判断质数)B - 是我仅会的GCD还是素数筛呢? G. Goodbye
(博弈)(思维)(试除法判断质数)B - 是我仅会的GCD还是素数筛呢? G. Goodbye
57 0
【每日一题Day87】LC1819序列中不同最大公约数的数 | 数学
由于数组中的最大公约数不可能超过子序列的最大值,因此可以枚举所有可能的最大公约数来判断当前的公约数是否有子序列构成。
118 0