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函数和过程(三)
--加密32位字符select md5('123456') --获取字符串的长度(一个中文三个长度)select LENGTH('呵呵') --获取字符串字符个数select CHAR_LENGTH( ...
- MongoDB数据库、集合、文档的操作
MongoDB系列第一课:MongDB简介 MongoDB系列第二课:MongDB环境搭建 MongoDB系列第三课:MongDB用户管理 MongoDB系列第四课:MongoDB数据库.集合.文档的 ...
- Ubuntu 安装 QtCreator (version : Qt 5.9.8)
平台 :Ubuntu 16.04 QT :5.9.8 (open source) 首先去QT安装包下载安装包,为了保持与arm板子的统一,本人选择了 5.9.8 版本的QT 可 ...
- 利用ant-design封装react的地址输入组件
在上一节利用element-ui封装地址输入的组件留下了个尾巴,说react搭配ant-design封装一下地址输入的组件的.本来应该早早就完成的,但是由于这中间发生了一些事情,导致了突发性的换了工作 ...
- 怎样修改 VS Code 主题?
方法1. 点击左上角 File > Preferences > Color Theme. 方法2. 使用快捷键: Ctrl + K , Ctrl + T PS: 查询各种操作的快捷键可以 ...
- StoneTab标签页CAD插件 3.2.3
//////////////////////////////////////////////////////////////////////////////////////////////////// ...
- arcgis js之地图分屏同步
arcgis js之地图分屏同步 原理: 新建两个map两个view或者一个map两个view.对地图进行移动事件绑定,在地图移动时同步地图方位 代码: views.forEach((view) =& ...
- 浅谈Promise原理与应用
在JavaScript中,所有代码都是单线程.由于该“缺陷”,JavaScript在处理网络操作.事件操作时都是需要进行异步执行的.AJAX就是一个典型的异步操作 对于异步操作,有传统的利用回调函数和 ...
- linux下Django Nginx+uwsgi 安装配置
原文链接 在前面的章节中我们使用 python manage.py runserver 来运行服务器.这只适用测试环境中使用. 正式发布的服务,我们需要一个可以稳定而持续的服务器,比如apache, ...
- lua table vs closure
最近在重构自己写的框架中的定时器模块,需要把回调函数保存起来,大概如下: function timer_mgr:save_timer( this,callback ) return { this = ...