【NOIP模拟赛】秦时明月
秦时明月
(sword.cpp/c/pas)
【问题描述】
卫庄与盖聂又要论剑了,因为渊虹和鲨齿都是天下名剑,论剑容易互相损伤,太过可惜,于是两位换了两把木剑。因为木剑质地不匀,剑的每一段都有一个坚韧值,论剑时不定两把剑会如何相碰,即剑相碰时可以想象为两把剑上的随机各选一段相碰,两把剑上的每一段被选中的概率都相等,柔韧值高的自然是赢家。现在已知卫庄盖聂手上的剑各有几段,每段柔韧值是多少,求盖聂的胜率(用最简分数的形式表示出来)。
【输入格式】
第一行包含用空格隔开的 2 个正整数 N,M。分别表示卫庄、盖聂手上的剑一共有多少段
第二行有 N 个正整数 Ai,表示卫庄手上的剑每段的坚韧值
第三行有 M 个正整数 Bi,表示盖聂手上的剑每段的坚韧值
【输出格式】
输出文件应包含两个正整数 U,D,表示盖聂的胜率为 U/D(最简形式)
【输入样例】
2 2 1 4 2 3
【输出样例】
1 2
【数据规模与约定】
对于 30%的数据 N,M≤1000
对于 70%的数据 N,M≤100000
对于 100%的数据 N,M≤1000000,Ai,Bi≤10^9
【试题分析】
乍一看:水题!哈哈!
再一看:数据规模有点大
当然,暴力党们肯定是能水过30%了,一个一个比对就可以了。
但是话说我们今天不是去关注30%的题解,我们的目标是100%(突然想起来黄学长的:我们的征途是星辰大海QAQ,是不是很押韵?)
代码实现起来其实很简单,但在这背后有许多思考。
我们先来谈谈70%怎么过吧!
一开始可以想到只用一个数组存储,先把第一个人的数据存下来,再在第二个人的输入过程中处理。
这只是省了一点点空间而已,现在我们要来省省时间了。
其实排一个序就足以解决70分的所有问题。
先让第一个人的数据输入完,然后再排一下序,这当然是对答案没有任何影响的。
然后第二个人输入的每一次数据从a[1]一直到比它小的最后一个就都是可以赢的情况,所以我们可以这样优化。
那100%你应该想到了吧!
你肯定知道一个叫鹅粪查找的东西吧!
恍然大悟?
我们可以直接加下标啊!何必一个一个去试呢?
因此,我们只需要查找最后一个比输入元素小的下标。
如果你的gcd不是傻傻的暴力,而且输入不是傻傻的cin的话,应该就能过了
是不是很神奇!?
我们来看代码吧!
【代码】
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
int a[1000100];
long long U,D;
int b;
int M,N;
bool w=false;
int binary_search(int* a,int len,int goal)
{
int low=1;
int high=len;
while(low<=high)
{
int middle=(high-low)/2+low;
if (a[middle]==goal){w=true;return middle;}
else if(a[middle]>goal) high=middle-1;
else low=middle + 1;
}
return low;
}
long long gcd(long long a,long long b)
{
return b==0?a:gcd(b,a%b);
}
int main()
{
scanf("%d%d",&N,&M);
D=(long long)N*M;
for(int i=1;i<=N;i++) scanf("%d",&a[i]);
sort(a+1,a+N+1);
for(int i=1;i<=M;i++)
{
scanf("%d",&b);
w=false;
int at=binary_search(a,N,b);
if(w==false) at--;
U+=at;
}
long long gcdans=gcd(U,D);
U/=gcdans;
D/=gcdans;
printf("%lld %lld",U,D);
}
【NOIP模拟赛】秦时明月的更多相关文章
- NOIP模拟赛20161022
NOIP模拟赛2016-10-22 题目名 东风谷早苗 西行寺幽幽子 琪露诺 上白泽慧音 源文件 robot.cpp/c/pas spring.cpp/c/pas iceroad.cpp/c/pas ...
- contesthunter暑假NOIP模拟赛第一场题解
contesthunter暑假NOIP模拟赛#1题解: 第一题:杯具大派送 水题.枚举A,B的公约数即可. #include <algorithm> #include <cmath& ...
- NOIP模拟赛 by hzwer
2015年10月04日NOIP模拟赛 by hzwer (这是小奇=> 小奇挖矿2(mining) [题目背景] 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿 ...
- 大家AK杯 灰天飞雁NOIP模拟赛题解/数据/标程
数据 http://files.cnblogs.com/htfy/data.zip 简要题解 桌球碰撞 纯模拟,注意一开始就在袋口和v=0的情况.v和坐标可以是小数.为保险起见最好用extended/ ...
- 队爷的讲学计划 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的讲学计划 题解:刚开始理解题意理解了好半天,然后发 ...
- 队爷的Au Plan CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的Au%20Plan 题解:看了题之后觉得肯定是DP ...
- 队爷的新书 CH Round #59 - OrzCC杯NOIP模拟赛day1
题目:http://ch.ezoj.tk/contest/CH%20Round%20%2359%20-%20OrzCC杯NOIP模拟赛day1/队爷的新书 题解:看到这题就想到了 poetize 的封 ...
- CH Round #58 - OrzCC杯noip模拟赛day2
A:颜色问题 题目:http://ch.ezoj.tk/contest/CH%20Round%20%2358%20-%20OrzCC杯noip模拟赛day2/颜色问题 题解:算一下每个仆人到它的目的地 ...
- CH Round #52 - Thinking Bear #1 (NOIP模拟赛)
A.拆地毯 题目:http://www.contesthunter.org/contest/CH%20Round%20%2352%20-%20Thinking%20Bear%20%231%20(NOI ...
- CH Round #49 - Streaming #4 (NOIP模拟赛Day2)
A.二叉树的的根 题目:http://www.contesthunter.org/contest/CH%20Round%20%2349%20-%20Streaming%20%234%20(NOIP 模 ...
随机推荐
- 【转】深入理解TextView实现Rich Text--在同一个TextView设置不同字体风格
深入理解TextView实现Rich Text--在同一个TextView设置不同字体风格 作者: 字体:[增加 减小] 类型:转载 本篇文章是对Android中在同一个TextView中设置不同 ...
- 深入理解Redis主键失效原理及实现机制
http://blog.jobbole.com/71095/ 对于缓存失效,不同的缓存有不同的处理机制,可以说是大同中有小异,作者通过对Redis 文档与相关源码的仔细研读,为大家详细剖析了 Redi ...
- 解决Android SDK Manager下载太慢问题
1.打开android sdk manager 2.打开tool->options,如图所示 3.将Proxy Settings 里的HTTP Proxy Server和HTTP Proxy P ...
- 成员变量NSString类型指针的属性为什么用copy(属性)
创建一个分类Person设置属性@property(nonatomic,strong) NSString * name; 在- (void)viewDidLoad 中打印测试 name的属性是stro ...
- The prefix "mx" for element "mx:WindowedApplication" is not bound.
<mx:WindowedApplication xmlns:fx="http://ns.adobe.com/mxml/2009" > ......出现了错误The p ...
- python中的yield
在理解yield之前,要首先明白什么是generator,在理解generator之前首先要理解可迭代的概念. 可迭代(iterables)在你创建一个list的时候,可以逐个读取其中的元素,该逐个读 ...
- 【转】Tomcat组件生命周期管理
Tomcat组件生命周期管理 Tomcat中Server,Service,Connector,Engine,Host,Context,它们都实现了org.apache.catalina.Lifecyc ...
- WebService之Axis2 后续(6)~(10)目录
WebService大讲堂之Axis2(6):跨服务会话(Session)管理 WebService大讲堂之Axis2(7):将Spring的装配JavaBean发布成WebService WebSe ...
- Tomcat系列之Java技术详解
一.概述 1.前言 在前面几篇博客中,我们和大家说了负载均衡器服务器.Web服务器.反向代理服务器.缓存服务器,从这篇博客开始我们和大家说说应用程序服务器,对于上述内容不了解的博友可以去参考一下我们前 ...
- PG sys function
The System Catalogs of PostgreSQLscott=# \dS List of relations Schema | Name | Type | Owner -------- ...