18113 Secret Book of Kungfu 按位DFS
http://acm.scau.edu.cn:8000/uoj/mainMenu.html
18113 Secret Book of Kungfu
该题有题解
时间限制:1000MS 内存限制:65535K
提交次数:0 通过次数:0
题型: 编程题 语言: 不限定
Description
Uncle Big is acknowledged as a master of kung fu. But he doesn't think so. He thinks that there are many other unknown
experts in the world. So Uncle Big devotes all his life to find the highest realm of kung fu.
During a chance, Uncle Big discover a secret book of kungfu in a cave. But the book is broken and losts many pages. What's
worst, there's only some numbers writted on the book. After studying the book years and years, Uncle Big discover that all
this numbers have a common feature that, the decimal notation of a number is a substring of its binary notation. So Uncle
Big want to restore the book, in order to better understand it. Before doing this, Uncle Big has to know how many such numbers
between l and r (inclusive).
But now Uncle Big is so exciting because of this discovering, and has gone to race boat. Can you help him?
输入格式
The input file begins with an integer T (T <= 10000) in one row indicating the number of test case. Then T test cases
follows.
Each test case contains one line with two non-negetive integer l and r (l <= r <= 1000000000000000(1e15) ).
输出格式
For each test case, print one line with a integer as answer.
输入样例
1
1 1000
输出样例
8
提示
"1", "0", "10", "01", "101" are the substring of "101", but "11", "00" are not.
考虑按位DFS后再暴力判断,然后发现总数只有283个,记得加上0,就284个。打个表二分查找就好。
dfs数字的话,一般就是dfs(cur * 10 + 0),这个数位进位后,然后加上想要的数字
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm>
#define IOS ios::sync_with_stdio(false)
using namespace std;
#define inf (0x3f3f3f3f)
typedef long long int LL; #include <iostream>
#include <sstream>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <string>
LL L, R;
int ans;
char str_bin[];
char num[];
int lenstr;
void bin(LL n) {
if (n / ) bin(n / );
str_bin[++lenstr] = n % + '';
}
LL biao[ + ];
int lenbiao;
void dfs(LL cur) {
if (cur >= L && cur <= R) {
lenstr = ;
bin(cur);
int k = ;
LL t = cur;
while (t / > ) {
num[++k] = t % + '';
t /= ;
}
num[++k] = t + '';
num[k + ] = '\0';
str_bin[lenstr + ] = '\0';
// cout << str_bin + 1 << endl; reverse(num + , num + + k);
// cout << num + 1 << endl;
// cout << endl;
char *p = strstr(str_bin + , num + );
if (p != NULL)
biao[++lenbiao] = cur;
}
if (cur > R) return;
dfs(cur * );
dfs(cur * + );
}
void work() {
cin >> L >> R;
if (L > R) swap(L, R);
int posR = lower_bound(biao + , biao + + lenbiao, R) - biao;
int posL = lower_bound(biao + , biao + + lenbiao, L) - biao;
if (biao[posL] == L && biao[posR] == R) {
cout << posR - posL + << endl;
} else if (biao[posL] == L && biao[posR] != R) {
cout << posR - posL << endl;
} else if (biao[posL] != L && biao[posR] == R) {
cout << posR - posL + << endl;
} else {
cout << posR - posL << endl;
}
}
void init() {
biao[++lenbiao] = ;
L = ;
R = 1e15L;
dfs();
sort(biao + , biao + + lenbiao);
}
int main() {
#ifdef local
freopen("data.txt","r",stdin);
#endif
IOS;
init();
int t;
cin >> t;
while (t--) work();
return ;
}
18113 Secret Book of Kungfu 按位DFS的更多相关文章
- hdoj 1342 Lotto【dfs】
Lotto Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submi ...
- hdu 5676 ztr loves lucky numbers(dfs+离线)
Problem Description ztr loves lucky numbers. Everybody knows that positive integers are lucky if the ...
- POJ 2676 Sudoku (数独 DFS)
Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 14368 Accepted: 7102 Special Judg ...
- HDU 5676 ztr loves lucky numbers【DFS】
题目链接; http://acm.hdu.edu.cn/showproblem.php?pid=5676 题意: 由4和7组成的且4和7出现次数相同的数称为幸运数字,给定n,求不大于n的最大幸运数字. ...
- codeforces 686C C. Robbers' watch(dfs)
题目链接: C. Robbers' watch time limit per test 2 seconds memory limit per test 256 megabytes input stan ...
- CodeForces 686C-Robbers' watch
题意: 一个电子手表的示数是7进制的,现在告诉你一天有多少小时和一小时有多少分钟,问你一天里有多少个时刻,这个表上显示的数字各不相同. 分析: 先找出表上有多少位数字,再按位dfs,看最后得到的数是否 ...
- 【一天一道LeetCode】#299. Bulls and Cows
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 You are ...
- 防盗链之URL参数签名
一.概述 传统的 IP 禁用.referer 防盗链.User-Agent 防盗链.地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链 二.实现 Token防盗链是 ...
- 防盗链之URL参数签名 总结
一.概述 传统的 IP 禁用.referer 防盗链.User-Agent 防盗链.地区访问控制等防盗链措施已经无法完全满足用户要求,所以开发出URL参数签名方式来防盗链 二.实现 Token防盗链是 ...
随机推荐
- eclipse订制快捷键
步骤: 1.window-preference. 2.在(1)处输入keys,在(2)处输入命令的原来的快捷键,方便找到Binding,在(3)处输入自定义的快捷键.点击“apply and clos ...
- codeforces 469B Chat Online 解题报告
题目链接:http://codeforces.com/problemset/problem/469/B 题目意思:给出 Little Z 的上线时间段,分别是[a1, b1], [a2, b2],.. ...
- SDK Manager中勾选项
运行SDK Manager 勾选对应版本的SDK,从这里基本可以知道一个Android版本对应着一个版本的API. 其中每个包都有这么几个文件: Documentation for Android S ...
- bootstrap学习大纲
bootstrap 学习分三部分,分别是 css样式,css组件,js插件. 下面介绍三部分分别要学习的内容: 1.css样式:栅格系统,排版,代码,表格,表单,按钮,图片,辅助类,响应式工具. 2. ...
- LC_MESSAGES、语言文件po和mo互相转换
LANGUAGE, LC_ALL, LC_MESSAGES, LANG zz- - 关于这几个环境变量一般认为它们的作用是用来指定程序用户界面语言而且这几个环境变量的优先级是从左到右依次降低的大概 ...
- Java应用架构设计模块化模式与OSGI摘录
在Java中,最适合模块化的单元就是Jar文件. 代码层面我们关注的太多了,熟练的开发人员现在很少争论使用模式的好处,也不再识别哪个模式适合当前需要,因为都能够本能地使用各种设计原则和模式,从GoF的 ...
- npm安装cnpm淘宝镜像
npm set registry https://registry.npm.taobao.org # 注册模块镜像 npm set disturl https://npm.taobao.org/d ...
- HTML5.与JQUERY与AJAX常见面试题
1. HTML5 1.1.简要描述 HTML5中的本地存储 参考答案: 很多时候我们会存储用户本地信息到电脑上,例如:比方说用户有一个填充了一半的长表格,然后突然网络连接断开了,这样用户希望你能存储这 ...
- Flutter实战视频-移动电商-10.首页_FlutterSwiper轮播效果制作
10.首页_FlutterSwiper轮播效果制作 博客地址: https://jspang.com/post/FlutterShop.html#toc-5c2 flutter_swiper http ...
- LeetCode: 485 Max Consecutive Ones(easy)
题目: Given a binary array, find the maximum number of consecutive 1s in this array. Example 1: Input: ...