递进数字C++

给定两个整数 l,r(l≤r),请问 [l,r] 范围内,满足数字的任意相邻两位差值都恰好为 1,且数字至少有两位的数有多少个。

输入格式

第一行包含整数 T,表示共有 T 组测试数据。每组数据占一行,包含两个整数 l 和 r。

输出格式

每组数据输出一行,一个结果。

数据范围

1≤T≤100,

0≤l≤r≤3×108

输入样例:

2

1 10

1 100

输出样例:

1

17

cpp 复制代码
#include<iostream>
using namespace std;
int l,r,cnt;
void dfs(int x)
{
    if(x>r) return;
    if(x>=l&&x>=10) cnt++;
    int d=x%10;
    if(d) dfs(x*10+d-1);
    if(d<9) dfs(x*10+d+1);
}
int main()
{
    int T;
    cin>>T;
    while(T--)
    {
        cin>>l>>r;
        cnt=0;
        for(int i=1;i<=9;i++)
            dfs(i);
        cout<<cnt<<endl;
    }
    return 0;
}
相关推荐
surtr19 分钟前
全源最短路封装模板(APSP,Floyd求最小环,Floyd求最短路,Johnson算法)
c++·算法·数学建模·动态规划·图论
梭七y35 分钟前
【力扣hot100题】(105)三数之和
数据结构·算法·leetcode
Morwit43 分钟前
如何使用CMake构建Qt新项目
开发语言·c++·qt
zmzb01031 小时前
C++课后习题训练记录Day62
开发语言·c++
fpcc1 小时前
C++23中的模块应用说明之二整体说明和导出控制
c++·c++23
我想吃余2 小时前
【C++篇】C++11:线程库
开发语言·c++
CSDN_RTKLIB2 小时前
【静态初始化与动态初始化】术语对比
开发语言·c++
WhereIsMyChair2 小时前
DPO 核心损失函数β调大可以控制不偏离ref模型太远
人工智能·算法·机器学习
智者知已应修善业2 小时前
【组合数】2024-3-16
c语言·c++·经验分享·笔记·算法
天上飞的粉红小猪3 小时前
线程同步与互斥
linux·开发语言·c++