The Little Elephant very much loves sums on intervals.

This time he has a pair of integers l and r (l ≤ r).
The Little Elephant has to find the number of such integers x (l ≤ x ≤ r),
that the first digit of integer x equals the last one (in decimal notation). For example, such numbers as 101, 477474 or 9 will
be included in the answer and 47, 253 or 1020 will
not.

Help him and count the number of described numbers x for a given pair l and r.

Input

The single line contains a pair of integers l and r (1 ≤ l ≤ r ≤ 1018) —
the boundaries of the interval.

Please, do not use the %lld specifier to read or write 64-bit integers in С++. It is preferred to use cin, cout streams
or the %I64dspecifier.

Output

On a single line print a single integer — the answer to the problem.

Sample test(s)
input
2 47
output
12
input
47 1024
output
98
看了其他博客都是数位dp,我用了不同的解法。对于n,m,分别算出cal(n),cal(m),即(0,n]符合结果的数,然后算出cal(n)-cal(m-1);
#include<stdio.h>
#include<string.h>
int b[100]={0,1,2,3,4,5,6,7,8,9,11,22,33,44,55,66,77,88,99,101};
__int64 pow(int n,int m)
{
int i;
__int64 sum=1;
for(i=1;i<=m;i++){
sum=sum*n;
}
return sum;
} __int64 cal(__int64 n)
{
int len=0,i,j,sum;
if(n>=0 && n<=9)return n;
/*if(n>=10 && n<=99){ //这里两位数的可以在这里特判一下,时间会减少30ms;
for(i=1;i<=20;i++){
if(n>=b[i]){
sum=i;
}
else break;
}
return sum;
}*/ __int64 x=n,ans=0,t,num;
int a[100];
memset(a,0,sizeof(a));
while(x>0){
a[++len]=x%10;x=x/10;
}
ans=ans+9;
for(i=2;i<=len-1;i++){
ans=ans+9*pow(10,i-2);
}
if(len>2) ans=ans+a[len]*(pow(10,len-2))-pow(10,len-2); if(a[1]>=a[len]){
if(len>2)
{
ans=ans+(n-a[len]*pow(10,len-1))/10+1;
return ans;
}
else {ans=ans+a[len];return ans;}
}
t=n;
while((t%10)!=a[len]){ //如果最高位和最低位不同,那么先让这个数每次减一,减到最低位等于一开始的最高位,
t--; //然后看最高位的数是否改变,如果没有改变,那么总数加上除了首尾的中间一些数,如57895,取中间为789.
} //如果改变,则直接返回
if(len==2){
ans=ans+a[len]-1;return ans;
} if(t-a[len]*pow(10,len-1)<0){
return ans;
}
else{
ans=ans+(t-a[len]*pow(10,len-1))/10+1;
return ans;
}
} int main()
{
__int64 n,m,n1,m1;
int i,j;
//while(scanf("%I64d",&n)!=EOF)
while(scanf("%I64d%I64d",&n,&m)!=EOF)
{
printf("%I64d\n",cal(m)-cal(n-1));
//printf("%I64d\n",cal(n));
}
return 0;
}


今天又用数位dp的方法做了一下。
思路:先预处理出dp[i][j]表示第i位为j符合要求的数的个数,然后就和普通的数位dp一样了,算的时候算[0,r)的个数,那么最后答案就是solve(m+1)-solve(n)。这里注意pow函数精度不够,所以要自己手写一个。


#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<math.h>
#include<vector>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<string>
#include<algorithm>
#define inf 99999999
#define pi acos(-1.0)
#define maxn 1000050
#define MOD 1000000007
using namespace std;
typedef long long ll;
typedef long double ldb;
ll po[25];
void init1()
{
int i,j;
po[0]=1;
for(i=1;i<=18;i++)po[i]=po[i-1]*10;
} ll dp[24][12];
void init()
{
int i,j,k;
memset(dp,0,sizeof(dp));
for(j=0;j<=9;j++)dp[1][j]=1;
for(i=2;i<=19;i++){
for(j=0;j<=9;j++){
if(j==0){
for(k=0;k<=9;k++){
dp[i][j]+=dp[i-1][k];
}
}
else{
dp[i][j]=po[i-2];
}
}
}
}
ll solve(ll x)
{
int i,j,len=0;
ll t=x;
int wei[20];
while(t){
wei[++len]=t%10;
t/=10;
}
wei[len+1]=0;
if(len==1){
return x;
} ll sum=0;
for(i=len;i>=1;i--){
if(i==len){
for(j=0;j<wei[i];j++){
sum+=dp[i][j];
}
}
else{
if(i==1){
if(wei[1]>wei[len] ){
sum++;
}
}
else{
for(j=0;j<wei[i];j++){
sum+=po[i-2];
}
} }
}
return sum;
} int main()
{
//freopen("o.txt","w",stdout);
ll n,m;
int i,j;
init1();
init();
while(scanf("%I64d%I64d",&n,&m)!=EOF){
printf("%lld\n",solve(m+1)-solve(n) );
}
return 0;
}

A. Little Elephant and Interval的更多相关文章

  1. Codeforces D. Little Elephant and Interval(思维找规律数位dp)

    题目描述: Little Elephant and Interval time limit per test 2 seconds memory limit per test 256 megabytes ...

  2. Codeforces 204A Little Elephant and Interval

    http://codeforces.com/problemset/problem/204/A 题意:给定一个[L,R]区间,求这个区间里面首位和末尾相同的数字有多少个 思路:考虑这个问题满足区间加减, ...

  3. codeforces 204(Div.1 A) Little Elephant and Interval(贪心)

    题意: 有一种个位数与最高位数字相等的数字,求在l,r的范围内,这样的数字的个数. 思路: 找下规律就知道当当n>10的时候除去个位以后的答案等于n/10,然后考虑第一个数字是否小于最后一个.小 ...

  4. Codeforces Round #129 (Div. 2)

    A. Little Elephant and Rozdil 求\(n\)个数中最小值的个数及下标. B. Little Elephant and Sorting \[\sum_{i=1}^{n-1}{ ...

  5. Failure to find xxx in xxx was cached in the local repository, resolution will not be reattempted until the update interval of nexus has elapsed or updates are forced @ xxx

    问题: 在linux服务器上使用maven编译war时报错: 16:41:35 [FATAL] Non-resolvable parent POM for ***: Failure to find * ...

  6. [LeetCode] Find Right Interval 找右区间

    Given a set of intervals, for each of the interval i, check if there exists an interval j whose star ...

  7. [LeetCode] Insert Interval 插入区间

    Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessa ...

  8. angularjs 中的setTimeout(),setInterval() / $interval 和 $timeout

    $interval window.setInterval的Angular包装形式.Fn是每次延迟时间后被执行的函数. 间隔函数的返回值是一个承诺.这个承诺将在每个间隔刻度被通知,并且到达规定迭代次数后 ...

  9. MySQL interval()函数

    INTERVAL(N,N1,N2,N3,..........) INTERVAL()函数进行比较列表(N,N1,N2,N3等等)中的N值.该函数如果N<N1返回0,如果N<N2返回1,如果 ...

随机推荐

  1. ctfhub技能树—sql注入—字符型注入

    打开靶机 查看页面信息 查询回显位 查询数据库名(查询所有数据库名:select group_concat(schema_name) from information_schema.schemata) ...

  2. disfunc绕过

    绕过DisFunc的常见小技巧 解析webshell命令不能执行时的三大情况 一是 php.ini 中用 disable_functions 指示器禁用了 system().exec() 等等这类命令 ...

  3. 国人之光:大数据分析神器Apache Kylin

    一.简介 Apache Kylin是一个开源的.分布式的分析型数据仓库,提供Hadoop/Spark 之上的 SQL 查询接口及多维分析(OLAP)能力以支持超大规模数据,最初由 eBay 开发并贡献 ...

  4. 全球城市ZoneId和UTC时间偏移量的最全对照表

    前言 你好,我是A哥(YourBatman). 如你所知,现行的世界标准时间是UTC世界协调时,时区已不直接参与时间计算.但是呢,城市名称or时区是人们所能记忆和容易沟通的名词,因此我们迫切需要一个对 ...

  5. [Ceoi2004]Journey

    题目描述 给出N个点,及你的出发点K. 接下来N-1行描述有关边的开始点,结束点,边长.保证图中不会有环 接下来给出数字J,代表你要走多少个点. 接下来J个数字,代表你要走过的点的编号.当然你可以自己 ...

  6. 【.NET 与树莓派】矩阵按键

    欢迎收看火星卫视,本期节目咱们严重探讨一下矩阵按键. 所谓矩阵按键,就是一个小键盘(其实一块PCB板),上面有几个 Key(开关),你不按下去的时候,电路是断开的,你按下去电路就会接通.至于说有多少个 ...

  7. .net code+vue 文件上传

    后端技术 .net code 官方文档 https://docs.microsoft.com/zh-cn/aspnet/core/mvc/models/file-uploads?view=aspnet ...

  8. pytest:conftest.py文件

    一.fixture scope 为session 级别是可以跨 .py模块调用的,也就是当我们有多个 .py文件的用例时,如果多个用例只需调用一次fixture,可以将scope='session', ...

  9. Vue基础之Vue组件

    Vue基础之Vue组件 // 组件是可以复用的Vue实例! // 可以把经常重复的功能封装为组件!

  10. Docker的Ubuntu镜像安装的容器无ifconfig命令和ping命令

    就这三步骤,下面的是实例不看也罢. apt-get update ###第一步一定要先执行这个更新下.不更新下面的安装命令会显示找不到网络包 //ifconfig apt install net-to ...