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. checkBox复选框,获得选中那一行所有列的数据

    function showCol(){ var check=$("input[name='one']:checked");//选中的复选框 check.each(function( ...

  2. cygwin gcc 编译windowsAPI 报错的一个解决方案

    一开始按照linux的习惯去编译一个使用了windowsAPI的程序 结果提示: $ i686-pc-cygwin-g++ screen_catch.cscreen_catch.c: In funct ...

  3. Python http.server中获取Post的请求报文

    今天在自学http.server请求命令, 各个字段都很好理解, 但唯独想打印获取Post请求报文时, 被难住了, 网上找了很多帖子, 官方的文档也刷了几遍, 但没有一个明确的答复. 后来不经意间看到 ...

  4. LocalDate与Date转化

    // 01. java.util.Date --> java.time.LocalDateTimepublic void UDateToLocalDateTime() { java.util.D ...

  5. 怎样初始化XMLHttpRequest实例对象xhr

    xhr.open() 接收5个参数, 用于初始化一个http请求, 它接收5个参数: 1. method: 请求类型; 2. url: 请求的url; 3. async: 是否为异步, 默认为true ...

  6. 怎样获取当前网页的URL

    1. document.documentURI document.documentURI; // "https://i.cnblogs.com/EditPosts.aspx?opt=1&qu ...

  7. 用Activator.CreateInstance代替new实现类的实例化

    一直想得到这样一个函数,输入一个类的名称为参数,返回一个相应的类的实例. 这在工厂模式中是非常有用的 这样,可以使程序有更高的扩展性,例如,,下面的例子 如果现在有一个类,专门用来计算交通工具的速度, ...

  8. .net core 根据数据库生成实体类

    微软最近几年在跨平台上不断发力,很多.net程序员也摩拳擦掌,对微软寄以厚望.就在最近,微软还推出了asp .net core2.0预览版. 通过对.net core的简单尝试,我发现以往我们开发MV ...

  9. 关于如何查看 MySQL 信息、查看Oracle 版本

    方法一: 进入mysql cmd, mysql -u root status; 将显示当前mysql的version的各种信息. 方法二: 还是在mysql的cmd下,输入: select versi ...

  10. net core体系-Xamarin-2概要(lignshi)

    通过本套课程的学习,各位学员能够对Xamarin有一个比较清楚的认识,掌握Xamarin常用功能的使用方法,能够比较熟练的使用Xamarin进行App(移动应用)的开发,能够比较轻松.快速地投入项目当 ...