基础算法分治

基础算法(分治)

分治算法上的思想是讲一个规模很大的问题分解为n个规模较小的子问题,这问题子问题相互独立且与原问题性质相同。求出子问题的解,就可以得到原问题的解。 [ 维基百科 ]


1.1计数问题
给定两个数a和b ,计算出1在a和b之间的出现的次数。例如,如果a =1024,b= 1032;那么a和b之间的数就是:
1024,1025,1026,1027,1028,1029,1030,1031,1032
则有10个1出现在这些数之间。
输入:
输入不会超过500行,每一行有两个数a和b,其中a>0 ,b<100 000 000 。输入两个0时程序结束,两个0不作为输入样例。
输出:
对于每一个输入的a和b,输出一个数,代表1出现的个数。
1.2
代码:

#include <iostream>
using namespace std;
const int N =11;
int d[N];
int value;
void deal(int n);
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()
{   int a,b;
    while(cin>>a>>b)
    {
    if(a==0&&b==0) break;
    if(a<b){int temp = b;b=a;a=temp;}
    for(int i =0;i<10;i++)
        d[i]=0;
    value = 1;
    deal(a);
    value = -1;
    deal(b);
    cout<<d[1]<<endl;
    }
    return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值