51Nod 1010 只包含因子2 3 5的数
第1行:一个数T,表示后面用作输入测试的数的数量。(1 <= T <= 10000)
第2 - T + 1行:每行1个数N(1 <= N <= 10^18)
共T行,每行1个数,输出>= n的最小的只包含因子2 3 5的数。
5
1
8
13
35
77
2
8
15
36
80
开始直接暴力试了一波,TLE。后面一想似乎可以先打表,再二分查找。打表还是一个技术活。
//Asimple
#include <bits/stdc++.h>
#define swap(a,b,t) t = a, a = b, b = t
#define CLS(a, v) memset(a, v, sizeof(a))
#define debug(a) cout << #a << " = " << a <<endl
#define test() cout<<"=========="<<endl
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;
const int maxn = +;
ll n, m, res, ans, len, T, k, num, sum, t;
ll a[maxn]; void init(){
ll er, san, wu;
er = san = wu = ;
a[] = ;
len = ;
while( a[len]<=1e18 ) {
a[++len] = min(*a[er], min(*a[san], *a[wu]));
if( a[len]==*a[er] ) er ++;
if( a[len]==*a[san] ) san ++;
if( a[len]==*a[wu] ) wu ++;
}
} ll b_search(ll low, ll high, ll num){
while( low<high ) {
ll mid = (low+high)/;
if( a[mid]==num ) return num;
else if(a[mid]<num ) low = mid+;
else high = mid;
}
return a[low];
} void input() {
ios_base::sync_with_stdio(false);
init();
cin >> T;
while( T -- ) {
cin >> n;
ans = b_search(, len, n);
cout << ans << endl;
}
} int main(){
input();
return ;
}
51Nod 1010 只包含因子2 3 5的数的更多相关文章
- 51nod 1010 只包含因子2 3 5的数 二分答案
		
1010 只包含因子2 3 5的数 K的因子中只包含2 3 5.满足条件的前10个数是:2,3,4,5,6,8,9,10,12,15. 所有这样的K组成了一个序列S,现在给出一个数n,求S中 > ...
 - 51nod 1010 只包含因子2 3 5的数 打表
		
只包含因子2 3 5的数 题目连接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1010 Description K的 ...
 - 51Nod 1010 只包含因子2 3 5的数 Label:None
		
K的因子中只包含2 3 5.满足条件的前10个数是:2,3,4,5,6,8,9,10,12,15. 所有这样的K组成了一个序列S,现在给出一个数n,求S中 >= 给定数的最小的数. 例如:n = ...
 - 51Nod 1010 只包含因子2 3 5的数(打表+二分)
		
K的因子中只包含2 3 5.满足条件的前10个数是:2,3,4,5,6,8,9,10,12,15. 所有这样的K组成了一个序列S,现在给出一个数n,求S中 >= 给定数的最小的数. 例如:n = ...
 - 51nod 1010 只包含因子2 3 5的数 && poj - 1338 Ugly Numbers(打表)
		
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1010 http://poj.org/problem?id=1338 首先 ...
 - 51Nod 1010 只包含因子2 3 5的数 | 预处理+二分
		
Input示例 5 1 8 13 35 77 Output示例 2 8 15 36 80 分析:将所有的只含有2 3 5因子的数打一个表保存在一个数组里,然后二分查找第一个>=数组里的数,输出 ...
 - 1007 正整数分组    1010 只包含因子2 3 5的数    1014 X^2 Mod P    1024 矩阵中不重复的元素    1031 骨牌覆盖
		
1007 正整数分组 将一堆正整数分为2组,要求2组的和相差最小. 例如:1 2 3 4 5,将1 2 4分为1组,3 5分为1组,两组和相差1,是所有方案中相差最少的. Input 第1行:一个 ...
 - 只包含因子2 3 5的数(51NOD 1010)
		
K的因子中只包含2 3 5.满足条件的前10个数是:2,3,4,5,6,8,9,10,12,15. 所有这样的K组成了一个序列S,现在给出一个数n,求S中 >= 给定数的最小的数. 例如:n = ...
 - 把只包含因子2、3和5的数称作丑数(Ugly Number)。例如6、8都是丑数,但14不是,因为它包含因子7。 习惯上我们把1当做是第一个丑数。求按从小到大的顺序的第N个丑数。
		
// ConsoleApplication1.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include<iostream> ...
 
随机推荐
- java应用监控工具
			
http://hao.jobbole.com/category/java/java-monitoring/
 - macOS Sierra(10.12.6), odoo(11.0), Python(3.5.4)配置
			
欣闻odoo11支持python3环境了,赶紧在mac平台尝试一下: 前期设置,参考另篇文章:macOS Sierra 10.12.6 odoo 10.0 开发环境配置 因为odoo11尚未正式发布, ...
 - easywechat (在thinkphp5中使用easywechat完成微信网页认证)
			
由于在easywechat中没有提及在thinkphp中的使用,后来我在http://www.thinkphp.cn/topic/45416.html中找到了有人已经封装了一下,我把自己使用的过程写下 ...
 - mui 滑块开关  进度条  以及如何获取值
			
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name ...
 - js运用4
			
---恢复内容开始--- 1.函数 关键字function 复习 var 是js的关键字,用于声明变量,声明在内存模块完成,定义(=)是在执行模块完成. var可以在内存模块提前(js代码执行 ...
 - ERP项目实施记录09
			
今天报价软件测试版本出来了,可看上去不怎么像是一款报价的软件,整个界面上都没有"报价"相关的字眼: 软件标题就不说了,反正影响不大,就当没看见,可左边这一大片菜单里也找不到和报价有 ...
 - python全栈开发   *   33 知识点汇总   *    180718
			
33 udp协议编码 显示客户端名字,输出带颜色的内容 udp协议的时间同步机制 #一.udp 协议编码 一个服务器,多个客户端#服务器:# import socket# sk=socket.sock ...
 - android json解析及简单例子+Android与服务器端数据交互+Android精彩案例【申明:来源于网络】
			
android json解析及简单例子+Android与服务器端数据交互+Android精彩案例[申明:来源于网络] android json解析及简单例子:http://www.open-open. ...
 - ELK之安装searchguard后默认管理员用户admin修改
			
安装完elasticsearch之后会有一个默认的用户admin密码也为admin,该用户无法删除无法编辑修改密码,用于生产时安全性较差,需要修改默认密码或者删除该admin用户 使用工具生产加密密码 ...
 - linux文件系统变为只读解决
			
linux控制台显示文件系统变为只读,需输密码或者按ctrl+d结束 输入root密码后执行fsck -y /dev/sda1,fsck -y /dev/sda2和fsck -y /dev/sda3等 ...