基础算法(分治)
分治算法上的思想是讲一个规模很大的问题分解为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;
}