hiho #1284 机会渺茫
#1284 : 机会渺茫
描述
小Hi最近在追求一名学数学的女生小Z。小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要求:对于给定的两个正整数N和M,小Hi随机选取一个N的约数N',小Z随机选取一个M的约数M',如果N'和M'相等,她就答应小Hi。
小Z让小Hi去编写这个随机程序,到时候她review过没有问题了就可以抽签了。但是小Hi写着写着,却越来越觉得机会渺茫。那么问题来了,小Hi能够追到小Z的几率是多少呢?
输入
每个输入文件仅包含单组测试数据。
每组测试数据的第一行为两个正整数N和M,意义如前文所述。
对于40%的数据,满足1<=N,M<=106
对于100%的数据,满足1<=N,M<=1012
输出
对于每组测试数据,输出两个互质的正整数A和B(以A分之B表示小Hi能够追到小Z的几率)。
- 样例输入
- 
3 2 
- 样例输出
- 
4 1 提示:f[i]用来标记i为n的约数,m/i也为约数。然后遍历m约数的时候,如果f[i]存在,即i为n,m公共约数。最后需要求最大公约数,通分。 
 AC代码:#include "iostream" 
 #include "math.h"
 #include "map"
 #define MAX 1000000 using namespace std;
 typedef long long LL; LL n, m;
 map<LL, int>f; LL gcd(LL a, LL b)
 {
 if (b == )
 return a;
 else
 return gcd(b, a%b);
 } int main()
 {
 cin >> n >> m;
 LL p = , q = , r = ;
 LL gcdnum; for (LL i = ; i*i <= n; i++){
 if (n % i == )
 {
 f[i] = ;
 f[n / i] = ;
 p++;
 if (i != n / i)
 p ++;
 }
 } for (LL i = ; i*i <= m; i++){
 if (m % i == )
 {
 q++;
 if (f[i])
 r++; if (i != m / i)
 {
 q++;
 if (f[m / i])
 r++;
 }
 }
 } gcdnum = gcd(p*q, r); cout << p*q / gcdnum << " " << r / gcdnum; }
hiho #1284 机会渺茫的更多相关文章
- hihocoder 1284 - 机会渺茫
		N有N_cnt个约数,M有M_cnt个约数,那么总共有N_cnt * M_cnt种对应情况. 假设其中有D_cnt个对应结果是相等的,而这D_cnt个数正好是gcd(N,M)的所有约数. 例如: N= ... 
- hihoCoder1284机会渺茫(唯一分解定理 + 约分)
		题目链接 #1284 : 机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出 ... 
- hiho一下 第144周(机会渺茫)解题报告及拓展
		题目1 : 机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要求: ... 
- hihocoder-1284 机会渺茫(水题)
		机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要求:对于给定的两 ... 
- 【hiho一下 第144周】机会渺茫
		[题目链接]:http://hihocoder.com/contest/hiho144/problem/1 [题意] [题解] 找出两个数相同的因子的个数x 然后两个数各自的因子的个数numa,nub ... 
- hiho一下 第144周
		题目1 : 机会渺茫 时间限制:5000ms 单点时限:1000ms 内存限制:256MB 描述 小Hi最近在追求一名学数学的女生小Z.小Z其实是想拒绝他的,但是找不到好的说辞,于是提出了这样的要求: ... 
- 李学斌:论复杂系统中的应用间协作V3
		说明 本文主要讨论了巨型复杂业务系统的一种构建思路,力图实现决策意志的快速.准确.一致的下传并简化实施成本提供实施效率.通过全业务领域的即时流程编排,实现全网业务IT系统的快速建设与迭代.本文所讲的方 ... 
- WP老杨解迷:开发生态两极化和榜单乱象
		Windows Phone 自2013年的一片浪潮推动下,2014年终于开始引起了各大小CP们的注意,于是大量的产品开始乘风破浪一路涌进Windows Phone平台,立即改变了榜单的格局,如今,苦B ... 
- A Dream
		A Dream 2013年10月20日,成都,天气阴,铜牌16.离2012年10月14日长春现场赛刚好隔了一年,刚看了下去年写的总结http://blog.csdn.net/cc_again/arti ... 
随机推荐
- Git版本控制软件结合GitHub从入门到精通常用命令学习手册(转)
			简要参考:http://www.tuicool.com/articles/mEvaq2 http://gitref.org/zh/index.html GIT 学习手册简介 本站为 Git 学习参考手 ... 
- Java数据结构——用链表实现栈
			//================================================= // File Name : LinkStack_demo //---------------- ... 
- JavaWeb学习笔记——开发动态WEB资源(二)HelloWord
			该工程的功能是在页面上输出一段话 首先在src里面新建一个class,在interface里面添加javax.servlet.Servlet 以下是HelloServlet.java中的代码: pac ... 
- Eclipse 安装svn插件及使用
			1 安装 参考:http://welcome66.iteye.com/blog/1845176 通过svn插件安装,地址: Links for 1.8.x Release: Eclipse updat ... 
- 第3章 基本概念(第一部分:Js语法)
			本章就JavaScript常用功能而言阐述ECMAScript“伪语言”所描述的概念. 一. 语法 1.大小写规则 js语言本身对大小写不敏感,但是一切变量.函数.操作符都对大小写敏感. 2.注释格式 ... 
- 使用github和hexo搭建博客
			title: How to build your blog by Hexo in github Welcome to huihuang's blog,you will find what you ex ... 
- cmake 编译 c++ dll 的一个例子(更新2:增加 python 调用方法)
			CMakeLists.txt project(xxx) add_library(xxx SHARED xxx.cpp) add_executable(yyy yyy.cpp) target_link_ ... 
- asp.net常用函数表
			文章转载于[IT花园]:http://www.itgarden.com.cn/showtopic-29.aspx Abs(number) 取得数值的绝对值. Asc(String) 取得字符串表达式的 ... 
- web前端工程师校园招聘要求
			小燕子对紫薇说:“这辈子也别想着进皇宫了”.可后来她们不但进了宫,还都当上了格格.你在想什么?走呗! 1.去哪了网 前端开发工程师 工作地点:北京 工作职责: 负责去哪儿网各产品线Web前端研发: 负 ... 
- C# 获取进程或线程的相关信息
			信息来自: http://blog.163.com/kunkun0921@126/blog/static/169204332201293023432113/ using System; using S ... 
