UVa10288 Coupons 分数模版
题目非常简单, 答案就是 n/n+n/(n-1)+...+n/1;
要求分数输出。套用分数模板。。
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
const int maxn = 500; struct fraction {
long long numerator; // 分子
long long denominator; // 分母
fraction() {
numerator = 0;
denominator = 1;
}
fraction(long long num) {
numerator = num;
denominator = 1;
}
fraction(long long a, long long b) {
numerator = a;
denominator = b;
this->reduction();
} void operator = (const long long num) {
numerator = num;
denominator = 1;
this->reduction();
} void operator = (const fraction &b) {
numerator = b.numerator;
denominator = b.denominator;
this->reduction();
} fraction operator + (const fraction &b) const {
long long gcdnum = __gcd(denominator, b.denominator);
fraction tmp = fraction(numerator*(b.denominator/gcdnum) + b.numerator*(denominator/gcdnum), denominator/gcdnum*b.denominator);
tmp.reduction();
return tmp;
} fraction operator + (const int &b) const {
return ((*this) + fraction(b));
} fraction operator - (const fraction &b) const {
return ((*this) + fraction(-b.numerator, b.denominator));
} fraction operator - (const int &b) const {
return ((*this) - fraction(b));
} fraction operator * (const fraction &b) const {
fraction tmp = fraction(numerator*b.numerator, denominator * b.denominator);
tmp.reduction();
return tmp;
} fraction operator * (const int &b) const {
return ((*this) * fraction(b));
} fraction operator / (const fraction &b) const {
return ((*this) * fraction(b.denominator, b.numerator));
} void reduction() {
if (numerator == 0) {
denominator = 1;
return;
}
long long gcdnum = __gcd(numerator, denominator);
numerator /= gcdnum;
denominator /= gcdnum;
}
void print() {
if (denominator == 1) printf("%lld\n", numerator);
else {
long long num = numerator/denominator;
long long tmp = num;
int len = 0;
while (tmp) {
len++;
tmp/=10;
} for (int i = 0; i < len; i++) printf(" ");
if (len != 0) printf(" ");
printf("%lld\n",numerator%denominator); if (num != 0) printf("%lld ", num);
tmp = denominator;
while (tmp) {
printf("-");
tmp/=10;
}
puts(""); for (int i = 0; i < len; i++) printf(" ");
if (len != 0) printf(" ");
printf("%lld\n",denominator);
}
}
} f[maxn]; int main() {
int n;
while (scanf("%d", &n) != EOF) { f[0] = 0;
for (int i = 1; i <= n; i++)
f[i] = f[i-1] + fraction(1, i);
f[n] = f[n] * n; f[n].print();
}
return 0;
}
UVa10288 Coupons 分数模版的更多相关文章
- uva10288 Coupons 【概率 分数】
		题目: 题意: 一共n种不同的礼券,每次得到每种礼券的概率相同.求期望多少次可以得到所有n种礼券.结果以带分数形式输出.1<= n <=33. 思路: 假设当前已经得到k种,获得新的一种的 ... 
- [POJ2625][UVA10288]Coupons
		Description Coupons in cereal boxes are numbered 1 to n, and a set of one of each is required for a ... 
- 「SHOI2002」「LuoguP1291」百事世界杯之旅(UVA10288 Coupons)(期望,输出
		题目描述 “……在2002年6月之前购买的百事任何饮料的瓶盖上都会有一个百事球星的名字.只要凑齐所有百事球星的名字,就可参加百事世界杯之旅的抽奖活动,获得球星背包,随声听,更克赴日韩观看世界杯.还不赶 ... 
- uva 10288 Coupons  (分数模板)
		https://vjudge.net/problem/UVA-10288 大街上到处在卖彩票,一元钱一张.购买撕开它上面的锡箔,你会看到一个漂亮的图案. 图案有n种,如果你收集到所有n(n≤33)种彩 ... 
- 【poj 2976】Dropping tests(算法效率--01分数规划 模版题+二分){附【转】01分数规划问题}
		P.S.又是一个抽时间学了2个小时的新东西......讲解在上半部分,题解在下半部分. 先说一下转的原文:http://www.cnblogs.com/perseawe/archive/2012/05 ... 
- [NOIP2017赛前复习第二期]复赛考试技巧与模版-普及组
		考试技巧 1.拿到考卷首先通看题目,按自己感觉的难度排序(普及一般是1-2-3-4了~还是相信出题人不会坑我们的2333) 2.一般来说,普及组前两道题比较简单(大水题啊233~),但是通常坑很多,例 ... 
- UVA 10288 Coupons---概率 && 分数类模板
		题目链接: https://cn.vjudge.net/problem/UVA-10288 题目大意: 一种刮刮卡一共有n种图案,每张可刮出一个图案,收集n种就有奖,问平均情况下买多少张才能中奖?用最 ... 
- PHP.22-Smart模版
		Smart模版 smarty是一个基于PHP开发的PHP模板引擎.它提供了逻辑与外在内容的分离,简单的讲,目的就是要使PHP程序员同美工分离,使用的程序员改变程序的逻辑内容不会影响到美工的页面设计,美 ... 
- UVA 10288 - Coupons(概率递推)
		UVA 10288 - Coupons option=com_onlinejudge&Itemid=8&page=show_problem&category=482&p ... 
随机推荐
- S3C2440的内存情况在NAND FLASH或者NOR FLASH启动的情况下
			1,从NANDFLASH启动时,在ARM上电时,ARM会自动把NANDFLASH前4K的内容拷贝到S3C2440内部SRAM中,同时把SRAM的地址映射到0X00000000.ARM上电后会从SRAM ... 
- STM32F407 跑马灯 库函数版 个人笔记
			原理图: MCU在开发板原理图的第二页,LED在开发板原理图的第三页 由图可知,PF9 ,PF10 若输出低电平则灯亮,高电平则灯灭 选推挽输出 代码步骤 使能IO口时钟. 调用函数RCC_AHB1P ... 
- Webdriver测试脚本1(打开网页并打印标题)
			案例: 启动火狐浏览器 首页打开博客园页面,打印网页标题,等待3秒 打开百度首页,打印网页标题,再等待2秒 关闭浏览器 from selenium import webdriver from time ... 
- Bone Collector II(hdu 2639)
			题意:求01背包的第k最优值 输入:第一行为T,下面是T组数据,每组数据有n,m,k 代表n件物品,m容量,和题目要求的k,下一行是n个物品的价值,再一行是n个物品的体积 输出:T行答案 /* 类似于 ... 
- 开车旅行(codevs 1199)
			题目描述 Description 小A 和小B决定利用假期外出旅行,他们将想去的城市从1到N 编号,且编号较小的城市在编号较大的城市的西边,已知各个城市的海拔高度互不相同,记城市 i的海拔高度为Hi, ... 
- [NOIP2007] 提高组 洛谷P1098 字符串的展开
			题目描述 在初赛普及组的“阅读程序写结果”的问题中,我们曾给出一个字符串展开的例子:如果在输入的字符串中,含有类似于“d-h”或者“4-8”的字串,我们就把它当作一种简写,输出时,用连续递增的字母获数 ... 
- Linux下汇编语言学习笔记44 ---
			这是17年暑假学习Linux汇编语言的笔记记录,参考书目为清华大学出版社 Jeff Duntemann著 梁晓辉译<汇编语言基于Linux环境>的书,喜欢看原版书的同学可以看<Ass ... 
- centos7 host修改
			首先要说明,hostname和hosts文件没有必然联系,有不明白的同学可以先自行查阅资料了解hostname和hosts文件的关系.这里简要说明一下. hosts文件是dns服务的前身,网络刚开始出 ... 
- iLBC 压缩比
			*---------------------------------------------------* * ... 
- js数组转换成json串 (JSON.stringify)
			例如: var giftlist[1490011777] = []; giftlist[1490011777]['id'] = 1490011777; giftlist[1490011777]['na ... 
