洛谷 p1625
高精度
我以为这题必有高论,怎么想也想不出来,没想到竟是如此粗鄙做法。
我们写一个高精度模拟一下,然后枚举约数看是否能约分,由于我不会高精度除法,就抄了一发
其实这种两项之比和项数有关的数列是不能推通项的,只能暴力模拟
#include<bits/stdc++.h>
using namespace std;
const int N = ;
int n, m;
struct Bigint {
int a[N], len;
Bigint friend operator + (Bigint &A, Bigint &B)
{
Bigint C;
memset(C.a, , sizeof(C.a));
int lim = max(A.len, B.len);
for(int i = ; i <= lim; ++i)
{
C.a[i] += A.a[i] + B.a[i];
C.a[i + ] += C.a[i] / ;
C.a[i] %= ;
}
C.len = lim;
if(C.a[lim + ]) ++C.len;
return C;
}
Bigint friend operator * (Bigint A, int x)
{
for(int i = ; i <= A.len; ++i) A.a[i] *= x;
for(int i = ; i <= A.len; ++i)
{
A.a[i + ] += A.a[i] / ;
A.a[i] %= ;
}
while(A.a[A.len + ] >= )
{
++A.len;
A.a[A.len + ] += A.a[A.len] / ;
A.a[A.len] %= ;
}
if(A.a[A.len + ] > ) ++A.len;
return A;
}
Bigint friend operator / (Bigint &A, int x)
{
Bigint B;
int tot = ;
memset(B.a, , sizeof(B.a));
for(int i = A.len; i; --i)
{
tot = tot * + A.a[i];
B.a[i] = tot / x;
tot %= x;
}
B.len = A.len;
while(B.a[B.len] == ) --B.len;
return B;
}
void print()
{
for(int i = len; i; --i) printf("%d", a[i]);
puts("");
}
} down, up, base;
bool can_div(Bigint &A, int x)
{
int tot = ;
for(int i = A.len; i; --i) tot = (tot * + A.a[i]) % x;
return (tot == );
}
int main()
{
scanf("%d%d", &n, &m);
down.len = ;
down.a[] = ;
base.len = ;
base.a[] = ;
for(int i = m + ; i < n + m; ++i) base = base * i;
for(int i = ; i <= n; ++i)
{
up = up + base;
base = base * i;
base = base / (m + i);
}
for(int i = ; i < n + m; ++i)
{
if(can_div(up, i)) up = up / i;
else down = down * i;
}
for(int i = ; i < n + m; ++i) if(can_div(up, i) && can_div(down, i))
{
up = up / i;
down = down / i;
}
up.print();
down.print();
return ;
}
洛谷 p1625的更多相关文章
- 洛谷1640 bzoj1854游戏 匈牙利就是又短又快
bzoj炸了,靠离线版题目做了两道(过过样例什么的还是轻松的)但是交不了,正巧洛谷有个"大牛分站",就转回洛谷做题了 水题先行,一道傻逼匈牙利 其实本来的思路是搜索然后发现写出来类 ...
- 洛谷P1352 codevs1380 没有上司的舞会——S.B.S.
没有上司的舞会 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description Ural大学有N个职员,编号为1~N.他们有 ...
- 洛谷P1108 低价购买[DP | LIS方案数]
题目描述 “低价购买”这条建议是在奶牛股票市场取得成功的一半规则.要想被认为是伟大的投资者,你必须遵循以下的问题建议:“低价购买:再低价购买”.每次你购买一支股票,你必须用低于你上次购买它的价格购买它 ...
- 洛谷 P2701 [USACO5.3]巨大的牛棚Big Barn Label:二维数组前缀和 你够了 这次我用DP
题目背景 (USACO 5.3.4) 题目描述 农夫约翰想要在他的正方形农场上建造一座正方形大牛棚.他讨厌在他的农场中砍树,想找一个能够让他在空旷无树的地方修建牛棚的地方.我们假定,他的农场划分成 N ...
- 洛谷P1710 地铁涨价
P1710 地铁涨价 51通过 339提交 题目提供者洛谷OnlineJudge 标签O2优化云端评测2 难度提高+/省选- 提交 讨论 题解 最新讨论 求教:为什么只有40分 数组大小一定要开够 ...
- 洛谷P1371 NOI元丹
P1371 NOI元丹 71通过 394提交 题目提供者洛谷OnlineJudge 标签云端评测 难度普及/提高- 提交 讨论 题解 最新讨论 我觉得不需要讨论O long long 不够 没有取 ...
- 洛谷P1538迎春舞会之数字舞蹈
题目背景 HNSDFZ的同学们为了庆祝春节,准备排练一场舞会. 题目描述 在越来越讲究合作的时代,人们注意的更多的不是个人物的舞姿,而是集体的排列. 为了配合每年的倒计时,同学们决定排出——“数字舞蹈 ...
- 洛谷八月月赛Round1凄惨记
个人背景: 上午9:30放学,然后因为学校举办读书工程跟同学去书城选书,中午回来开始打比赛,下午又回老家,中间抽出一点时间调代码,回家已经8:50了 也许是7月月赛时“连蒙带骗”AK的太幸运然而因同学 ...
- 洛谷 P1379 八数码难题 Label:判重&&bfs
特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...
随机推荐
- vue基础---模板语法
Vue.js 使用了基于 HTML 的模板语法,允许开发者声明式地将 DOM 绑定至底层 Vue 实例的数据.所有 Vue.js 的模板都是合法的 HTML ,所以能被遵循规范的浏览器和 HTML 解 ...
- ThinkPHP---layer插件
[概论] (1)layer是基于jquery开发的一款美化弹框的插件,主要用于弹框效果的交互.但其他功能和组件也日益完善 官网:http://layer.layui.com 在线手册:http://w ...
- org.hibernate.AnnotationException: mappedBy reference an unknown target entity property
org.hibernate.AnnotationException: mappedBy reference an unknown target entity property: xxxxxxx 原因是 ...
- Java基础——面向对象(封装——继承——多态 )
对象 对象: 是类的实例(实现世界中 真 实存在的一切事物 可以称为对象) 类: 类是对象的抽象描述 步骤: 1.定义一个类 (用于 描述人:) ( * 人:有特征和行为) 2.根据类 创建对象 -- ...
- 洛谷——P1073 最优贸易
P1073 最优贸易 n 个城市间以 m 条有向道路连接, 小 T 从 1 号城市出发, 将要去往 n 号城市.小 T 观察到一款商品 Z 在不同的城市的价格可能不尽相同,小 T 想要在旅行中的某一个 ...
- Libreswan软件的密钥协商协议IKEv1主模式实现分析
Libreswan软件的密钥协商协议IKEv1主模式实现分析 1 协商过程 IKEv1(互联网密钥交换协议第一版)是IPsec VPN隧道协商使用的标准密钥协商协议,其协商过程如下图所示. 总共来回交 ...
- buf.readInt32BE()
buf.readInt32BE(offset[, noAssert]) buf.readInt32LE(offset[, noAssert]) offset {Number} 0 <= offs ...
- 1.Linux标准IO编程
1.1Linux系统调用和用户编程接口 1.1.1系统调用 用户程序向操作系统提出请求的接口.不同的系统提供的系统调用接口各不相同. 继承UNIX系统调用中最基本和最有用的部分. 调用按照功能分:进程 ...
- spring与quartz整合实现分布式动态创建,删除,改变执行时间定时任务(mysql数据库)
背景:因为在项目中用到了定时任务,当时想到了spring的quartz,写完发现费了很大功夫,光是整合就花了一上午,其中最大的问题就是版本问题,项目中用的是spring3.2.8的版本,查阅发现,3. ...
- 充当别的mcu的外部存储器(51类)
// 锁存地址 - STC12C5A60S2 reg [15:0]rAddr_51; //存放51单片机传过来的地址 读51地址寄存器 always @ (posedge MCLKout or neg ...