JAVA+大数搞了一遍- -

不是很麻烦- -

/*
HDU 6093 - Rikka with Number [ 进制转换,康托展开,大数 ] | 2017 Multi-University Training Contest 5
题意:
求L,R之间的好数的个数,好数要求在某个d(>=2)进制下数位是0到d-1的
分析:
d 进制下好数的个数为 d!-(d-1)! ,且满足 d^(d-1) <= K <= d^d
可知 若 N > d^d 则 1-N 包含前 d-1 个进制的所有好数
寻找零界 d 可以二分,将 N 和 d^d 比大小 计算临界的 d 进制的好数,用类似康托展开的过程
即 对于 (x0, x1, x2...xn),转化成
首位小于x0的所有排列+ 首位等于x0第二位小于x1的所有排列+.... */
import java.math.BigInteger;
import java.util.Scanner;
public class Main {
static Scanner cin = new Scanner(System.in);
static long MOD = 998244353;
static BigInteger a[] = new BigInteger[2000];
static long F[] = new long[2000];
static BigInteger bb;
static String s;
static int [] b = new int[5005];
static int [] c = new int[5005];
static int lc, lb;
static void init() {
F[0] = 1;
for (int i = 1; i < 2000; i++) F[i] = F[i-1] * i % MOD;
for (int i = 1; i < 2000; i++) a[i] = BigInteger.valueOf(i).pow(i);
}
static int BinaryFind(){
int l = 2, r = 1999, mid = 0;
while (l <= r) {
mid = (l+r)/2;
if (bb.compareTo(a[mid]) >= 0) l = mid+1;
else r = mid-1;
}
return l;
}
static void change(int m) {
lc = 0;
while (lb > -0) {
int x = 0;
for (int i = lb-1; i >= 0; i--) {
x = x*10 + b[i];
b[i] = x/m;
x %= m;
}
c[lc++] = x; while (lb > 0 && b[lb-1] == 0) lb--;
}
}
static int[] vis = new int[5005];
static long solve(){
int m = BinaryFind();
change(m);
long ans = F[m-1] - F[1];
if (m > lc) return ans;
for (int i = 0; i < m; i++) vis[i] = 0;
for (int i = 1; i < c[lc-1]; i++)
if (vis[i] == 0)
ans = (ans + F[lc-1]) % MOD;
vis[c[lc-1]] = 1;
for (int i = lc-2; i >= 0; i--)
{
for (int j = 0; j < c[i]; j++)
if (vis[j] == 0)
ans = (ans + F[i]) % MOD;
if (vis[c[i]] == 1) break;
vis[c[i]] = 1;
if (i == 0) ans = (ans + 1) % MOD;
}
return ans;
}
public static void main(String[] args) {
init();
int t = cin.nextInt();
while ((t--) != 0) {
bb = cin.nextBigInteger();
s = bb.toString();
lb = s.length();
for (int i = 0; i < lb; i++) {
b[i] = (int)(s.charAt(lb-1-i) - '0');
}
b[0]--;
for (int i = 0; i < lb; i++) {
if (b[i] < 0) {
b[i] += 10; b[i+1]--;
}
else break;
}
while (lb > 0 && b[lb-1] == 0) lb--;
long ans = solve();
bb = cin.nextBigInteger();
s = bb.toString();
lb = s.length();
for (int i = 0; i < lb; i++) {
b[i] = (int)(s.charAt(lb-1-i) - '0');
}
ans = (MOD + solve() - ans) % MOD;
System.out.println(ans);
}
}
}

  

HDU 6093 - Rikka with Number | 2017 Multi-University Training Contest 5的更多相关文章

  1. 2017 多校5 hdu 6093 Rikka with Number

    2017 多校5 Rikka with Number(数学 + 数位dp) 题意: 统计\([L,R]\)内 有多少数字 满足在某个\(d(d>=2)\)进制下是\(d\)的全排列的 \(1 & ...

  2. HDU 6091 - Rikka with Match | 2017 Multi-University Training Contest 5

    思路来自 某FXXL 不过复杂度咋算的.. /* HDU 6091 - Rikka with Match [ 树形DP ] | 2017 Multi-University Training Conte ...

  3. HDU 6088 - Rikka with Rock-paper-scissors | 2017 Multi-University Training Contest 5

    思路和任意模数FFT模板都来自 这里 看了一晚上那篇<再探快速傅里叶变换>还是懵得不行,可能水平还没到- - 只能先存个模板了,这题单模数NTT跑了5.9s,没敢写三模数NTT,可能姿势太 ...

  4. HDU 6085 - Rikka with Candies | 2017 Multi-University Training Contest 5

    看了标程的压位,才知道压位也能很容易写- - /* HDU 6085 - Rikka with Candies [ 压位 ] | 2017 Multi-University Training Cont ...

  5. HDU 6162 - Ch’s gift | 2017 ZJUT Multi-University Training 9

    /* HDU 6162 - Ch’s gift [ LCA,线段树 ] | 2017 ZJUT Multi-University Training 9 题意: N节点的树,Q组询问 每次询问s,t两节 ...

  6. HDU 6090 Rikka with Graph —— 2017 Multi-University Training 5

    Rikka with Graph Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) ...

  7. hdu 6088 Rikka with Rock-paper-scissors (2017 多校第五场 1004) 【组合数学 + 数论 + 模意义下的FFT】

    题目链接 首先利用组合数学知识,枚举两人的总胜场数容易得到 这还不是卷积的形式,直接搞的话复杂度大概是O(n^2)的,肯定会TLE.但似乎和卷积有点像?想半天没想出来..多谢Q巨提醒,才知道可以用下面 ...

  8. 2017 Wuhan University Programming Contest (Online Round) Lost in WHU 矩阵快速幂 一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开。

    /** 题目:Lost in WHU 链接:https://oj.ejq.me/problem/26 题意:一个无向图,求从1出发到达n最多经过T条边的方法数,边可以重复经过,到达n之后不可以再离开. ...

  9. 2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟

    /** 题目:C. Divide by Six 链接:https://oj.ejq.me/problem/24 题意:给定一个数,这个数位数达到1e5,可能存在前导0.问为了使这个数是6的倍数,且没有 ...

随机推荐

  1. MySQL主从同步报错1507

    mysql 从库上手动删除partiton后,主库未做修改.后期主库上删除partiton后,出现问题. 故障现场 Last_Errno: 1507 Last_Error: Error 'Error ...

  2. 初识RedisCluster集群

    为什么需要Redis集群 需要提高更大的并发量 Redis官方提出拥有10万QPS的请求量 如果业务需要Redis拥有100万的QPS 可以通过集群来提升并发量. 需要存储更大的数据量 一般服务器的机 ...

  3. 【LOJ】#3051. 「十二省联考 2019」皮配

    LOJ#3051. 「十二省联考 2019」皮配 当时我在考场上觉得这题很不可做... 当然,出了考场后再做,我还是没发现学校和城市是可以分开的,导致我还是不会 事实上,若一个城市投靠了某个阵营,学校 ...

  4. (三)mysql SQL 基本操作

    文章目录 MySQL服务器对象 mysql 的基本操作 SQL的注释 库操作 表(字段)操作 数据操作 MySQL服务器对象 mysql 服务器对象内部分成了 4 层: 系统(DBMS)----> ...

  5. mysqldump原理及实战

    使用mysqldump命令行工具创建逻辑备份: 注意mysqldump的版本和路径mysqldump命令创建的是逻辑备份,结果集有两种格式:一种是将数据转换成标准的SQL语句(一堆CREATE,DRO ...

  6. 系统学习机器学习之神经网络(三)--GA神经网络与小波神经网络WNN

    系统学习机器学习之神经网络(三)--GA神经网络与小波神经网络WNN 2017年01月09日 09:45:26 Eason.wxd 阅读数 14135更多 分类专栏: 机器学习   1 遗传算法1.1 ...

  7. myEclipse10安装以及破解

    这里需要下载一个破解补丁 https://pan.baidu.com/s/1ivE2yauZRDdDq8zBxpK06A 可以去网盘里下载, 下载后解压,会有如下文件 然后运行run.bat,会出现这 ...

  8. C# 批量设置窗体中控件状态的方法

    在开发中常遇到当点击某个按钮的时候,禁用文本框或按钮的的状态,以防止误操作,下面的代码是我已批量设置指定控件中的按钮状态的代码,同理可以延伸出很多操作. /// <summary> /// ...

  9. VBA精彩代码分享-1

    今天下班前分享一下之前在网上搜到的两段好用的VBA代码,貌似都来自国外,觉得挺好,模仿不来. 第一段的功能是修改VBA控件中的文本框控件,使其右键可以选择粘贴.复制.剪切等: Option Expli ...

  10. Qt的多线程总结以及使用(一)

    Qt提供QThread类以进行多任务的处理.Qt提供的线程可以做到单个进程做不到的事情.在这里实现最简单的一个多线程.最简单的线程的基类为QThread,然后需要重写QThread的run(),在ru ...