火题大战Vol.1 A.

题目描述

给定两个数\(x\),\(y\),比较\(x^y\) 与\(y!\)的大小。

输入格式

第一行一个整数\(T\)表示数据组数。

接下来\(T\)行,每行两个整数\(x\),\(y\),表示\(T\)组数据。

输出格式

输出有\(T\)行,对于每一组数据,如果\(x^y \leq y!\)

输出 \(Yes\),否则输出\(No\)。

样例

样例输入

3

1 4

2 4

3 4

样例输出

Yes

Yes

No

样例输入

5

50 100

37 100

200 1000

400 1000

20000 100000

样例输出

No

Yes

Yes

No

Yes

数据范围与提示

对于\(50\%\)的数据满足\(x \leq 8\),\(y \leq 10\)。

对于\(80\%\)的数据满足\(x\),\(y \leq 300\) 。

对于\(100\%\)的数据满足\(x\),\(y \leq 10^5\),\(T \leq 5\)。

分析

做法一:

比较套路,因为我们只需要比较数的大小,所以我们将\(a \times b\)转化为 \(log(a)+log(b)\)

代码

#include<bits/stdc++.h>
using namespace std;
typedef double db;
const double lqs=1e-9;
const int maxn=1e6+5;
db lg[maxn];
int main(){
int t;
scanf("%d",&t);
for(int i=1;i<maxn;i++){
lg[i]=log2(i);
}
while(t--){
int xx,yy;
scanf("%d%d",&xx,&yy);
double ans1=0,ans2=0;
for(int i=1;i<=yy;i++){
ans1=ans1+lg[xx];
}
for(int i=1;i<=yy;i++){
ans2=ans2+lg[i];
}
if(ans1-ans2>lqs) printf("No\n");
else printf("Yes\n");
}
return 0;
}

做法二

压位高精,但是因为博主比较菜,所以只能得到\(80\)分

代码

#include<bits/stdc++.h>
using namespace std;
const int maxn=1e4+5;
const int bas=1000;
struct bigint{
int a[maxn],len;
bigint(){
memset(a,0,sizeof(a));
len=0;
}
void qk(){
for(int i=1;i<=len;i++) a[i]=0;
len=0;
}
void Read(int aa){
while(aa){
a[++len]=aa%bas;
aa/=bas;
}
}
bigint operator *(const bigint &A)const{
bigint C;
C.len=A.len+len;
for(int i=1;i<=A.len;i++){
for(int j=1;j<=len;j++){
C.a[i+j-1]+=A.a[i]*a[j];
}
}
for(int i=1;i<=C.len;i++){
if(C.a[i]>=bas){
int cz=C.a[i]/bas;
C.a[i+1]+=cz;
C.a[i]%=bas;
}
}
if(C.a[C.len+1]) C.len++;
while(C.a[C.len]==0) C.len--;
return C;
}
void Write(){
for(int i=len;i>=1;i--){
printf("%.4d",a[i]);
}
printf("\n");
}
}ansa,ansb,zh;
int main(){
int t;
scanf("%d",&t);
while(t--){
int xx,yy;
scanf("%d%d",&xx,&yy);
ansa.qk(),ansb.qk();
ansa.Read(xx);
zh.qk();
zh.Read(xx);
for(int i=1;i<yy;i++){
ansa=ansa*zh;
}
ansb.Read(yy);
for(int i=1;i<yy;i++){
zh.qk();
zh.Read(i);
ansb=ansb*zh;
}
bool jud=0;
if(ansa.len>ansb.len){
printf("No\n");
jud=1;
}
else if(ansa.len<ansb.len){
printf("Yes\n");
jud=1;
}
else {
for(int i=ansa.len;i>=1;i--){
if(ansa.a[i]>ansb.a[i]){
printf("No\n");
jud=1;
break;
}
else if(ansa.a[i]<ansb.a[i]){
printf("Yes\n");
jud=1;
break;
}
}
if(jud==0)printf("Yes\n");
}
}
return 0;
}

火题大战Vol.1 A.的更多相关文章

  1. 火题大战Vol.0 B 计数DP

    火题大战Vol.0 B 题目描述 \(n\) 个沙茶,被编号 \(1\)~$ n$.排完队之后,每个沙茶希望,自己的相邻的两人只要无一个人的编号和自己的编号相差为 \(1\)(\(+1\) 或\(-1 ...

  2. 水题大战Vol.3 B. DP搬运工2

    水题大战Vol.3 B. DP搬运工2 题目描述 给你\(n,K\),求有多少个\(1\)到\(n\) 的排列,恰好有\(K\)个数\(i\) 满足\(a_{i-1},a_{i+1}\) 都小于\(a ...

  3. 金题大战Vol.0 A、凉宫春日的叹息

    金题大战Vol.0 A.凉宫春日的叹息 题目描述 给定一个数组,将其所有子区间的和从小到大排序,求第 \(k\) 小的是多少. 输入格式 第一行两个数\(n\),$ k\(,表示数组的长度和\)k$: ...

  4. 金题大战Vol.0 B、序列

    金题大战Vol.0 B.序列 题目描述 给定两个长度为 \(n\) 的序列\(a\), \(b\). 你需要选择一个区间\([l,r]\),使得\(a_l+-+a_r>=0\)且\(b_l+-+ ...

  5. 金题大战Vol.0 C、树上的等差数列

    金题大战Vol.0 C.树上的等差数列 题目描述 给定一棵包含\(N\)个节点的无根树,节点编号\(1-N\).其中每个节点都具有一个权值,第\(i\)个节点的权值是\(A_i\). 小\(Hi\)希 ...

  6. 土题大战Vol.0 A. 笨小猴 思维好题

    土题大战Vol.0 A. 笨小猴 思维好题 题目描述 驴蛋蛋有 \(2n + 1\) 张 \(4\) 星武器卡片,每张卡片上都有两个数字,第 \(i\) 张卡片上的两个数字分别是 \(A_i\) 与 ...

  7. [火星补锅] 水题大战Vol.2 T2 && luogu P3623 [APIO2008]免费道路 题解

    前言: 如果我自己写的话,或许能想出来正解,但是多半会因为整不出正确性而弃掉. 解析: 这题算是对Kruskal的熟练运用吧. 要求一颗生成树.也就是说,最后的边数是确定的. 首先我们容易想到一个策略 ...

  8. [火星补锅] 水题大战Vol.2 T1 && luogu P1904 天际线 题解 (线段树)

    前言: 当时考场上并没有想出来...后来也是看了题解才明白 解析: 大家(除了我)都知道,奇点和偶点会成对出现,而出现的前提就是建筑的高度突然发生变化.(这个性质挺重要的,我之前没看出来) 所以就可以 ...

  9. # 火题小战 A.玩个球

    火题小战 A.玩个球 题目描述 给你 \(n\) 种颜色的球,每个球有 \(k\) 个,把这 \(n\times k\) 个球排成一排,把每一种颜色的最左边出现的球涂成白色(初始球不包含白色),求有多 ...

随机推荐

  1. Git报错问题集锦

    git merge合并时遇上refusing to merge unrelated histories的解决方案 如果git merge合并的时候出现refusing to merge unrelat ...

  2. 台账建立和sqlite数据库的数据导入和导入问题

    principle platform command starts with "."; whiel sql command doesn't starts  with ". ...

  3. 【IDEA】HTML通过servlet3.0注解名提交表单到servlet类找不到页面的问题

    IDEA一时爽,摸不着头的BUG火葬场 这个问题困扰我整整一天一夜,先是代码检查路径设置找不出问题,后面换tomcat版不行,抱着侥幸心理换IDEA版本意料之中还是没解决问题. 都快想秃了最后终于完美 ...

  4. Android复习准备

    1. 四大组件是什么? Activity(活动):用于表现功能 Service(服务):后台运行服务,不提供界面呈现 BroadcastReceiver(广播接收器):用来接收广播 ContentPr ...

  5. python学习笔记1 -- 面向对象编程类和实例

    由于之前有一定基础,所以python中的类的概接受的比较快,与其他语言一样, python也是通过类来进行事务的抽象,一切皆对象,要不然怎么说程序员不缺对象呢. 言归正传,python中类的声明是cl ...

  6. pandas_时间序列和常用操作

    # 时间序列和常用操作 import pandas as pd # 每隔五天--5D pd.date_range(start = '',end = '',freq = '5D') ''' Dateti ...

  7. three.js之初探骨骼动画

    今后的几篇郭先生主要说说three.js骨骼动画.three.js骨骼动画十分有意思,但是对于初学者来说,学起来要稍微困难一些,官方文档比较少,网上除了用圆柱体的例子就是引用外部模型的,想要熟练使用骨 ...

  8. HTML <body> 标签

    HTML <body> 标签 实例 一个简单的 HTML 文档,包含尽可能少的必需的标签: <!DOCTYPE html> <html> <head> ...

  9. PHP ftp_systype() 函数

    定义和用法 ftp_systype() 函数返回 FTP 服务器的系统类型标识符. 如果成功,该函数返回系统类型.如果失败,则返回 FALSE. 语法 ftp_systype(ftp_connecti ...

  10. PHP metaphone() 函数

    实例 计算 "World" 的 metaphone 键: <?php高佣联盟 www.cgewang.comecho metaphone("World") ...