HDU 6093 - Rikka with Number | 2017 Multi-University Training Contest 5
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的更多相关文章
- 2017 多校5 hdu 6093 Rikka with Number
2017 多校5 Rikka with Number(数学 + 数位dp) 题意: 统计\([L,R]\)内 有多少数字 满足在某个\(d(d>=2)\)进制下是\(d\)的全排列的 \(1 & ...
- HDU 6091 - Rikka with Match | 2017 Multi-University Training Contest 5
思路来自 某FXXL 不过复杂度咋算的.. /* HDU 6091 - Rikka with Match [ 树形DP ] | 2017 Multi-University Training Conte ...
- HDU 6088 - Rikka with Rock-paper-scissors | 2017 Multi-University Training Contest 5
思路和任意模数FFT模板都来自 这里 看了一晚上那篇<再探快速傅里叶变换>还是懵得不行,可能水平还没到- - 只能先存个模板了,这题单模数NTT跑了5.9s,没敢写三模数NTT,可能姿势太 ...
- HDU 6085 - Rikka with Candies | 2017 Multi-University Training Contest 5
看了标程的压位,才知道压位也能很容易写- - /* HDU 6085 - Rikka with Candies [ 压位 ] | 2017 Multi-University Training Cont ...
- 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两节 ...
- 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) ...
- hdu 6088 Rikka with Rock-paper-scissors (2017 多校第五场 1004) 【组合数学 + 数论 + 模意义下的FFT】
题目链接 首先利用组合数学知识,枚举两人的总胜场数容易得到 这还不是卷积的形式,直接搞的话复杂度大概是O(n^2)的,肯定会TLE.但似乎和卷积有点像?想半天没想出来..多谢Q巨提醒,才知道可以用下面 ...
- 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之后不可以再离开. ...
- 2017 Wuhan University Programming Contest (Online Round) C. Divide by Six 分析+模拟
/** 题目:C. Divide by Six 链接:https://oj.ejq.me/problem/24 题意:给定一个数,这个数位数达到1e5,可能存在前导0.问为了使这个数是6的倍数,且没有 ...
随机推荐
- MYSQL SHOW 用法
1.SHOW CHARACTER SET 显示所有可用的字符集 mysql> SHOW CHARACTER SET LIKE 'utf8'; +---------+--------------- ...
- html中'disabled'与'readonly'的区别
html中'disabled'与'readonly'的区别 此随笔增量编辑 disabled 在提交表单的时候 值不会带入表单中, 而readonly则可以将值带入表单中.
- linux系统中启动mysql方式已经客户端如和连接mysql服务器
零点间的记录 一.启动方式1.使用linux命令service 启动:service mysqld start2.使用 mysqld 脚本启动:/etc/inint.d/mysqld start3.使 ...
- HttpServletResponse对象(转)
Web服务器收到客户端的http请求,会针对每一次请求,分别创建一个用于代表请求的request对象.和代表响应的response对象.request和response对象即然代表请求和响应,那我们要 ...
- C++11 bind和function用法
function是一个template,定义于头文件functional中.通过function<int(int, int)> 声明一个function类型,它是“接受两个int参数.返回 ...
- 【广搜】Knight Moves
题目描述 Mr Somurolov, fabulous chess-gamer indeed, asserts that no one else but him can move knights fr ...
- javascript之取余数、去商、天花板取整、地板取整
demo1: console.log('//求余数'); //求余数 console.log(5 % 4); console.log(6 % 4); //求商 console.log('//求商'); ...
- Spring实战(五)Spring中条件化地创建bean
1.@Conditional 为生成bean设置条件 Spring 4中引入了一个新的注解---@Conditional,它用在有@Bean的方法上. 如果给定条件计算结果为true,Spring会创 ...
- Hexo折腾记--小白修改新主题
UPDATE 2019.5.28 不好意思我又换了个新主题ARIA啦...这回没有个人定制了 前言 如果您曾经来过我的博客,就会发现我的个人博客(https://rye-catcher.github. ...
- css对应rgb码表16进制