貌似没什么用。。。没有多少毒瘤题要输出分数吧。。。

update:真的有,而且在NOIP模拟赛里出现了!写double的卡精度到怀疑人生!

可以套个兼容性比较好的高精度模板进来。

#include<bits/stdc++.h>
using namespace std;
namespace FlashHu{
#define RG register
#define I inline
#define R RG frac
#define OutputFormat 0
template<typename T>
T gcd(RG T a,RG T b){
return b?gcd(b,a%b):a;
}
template<typename T>
struct frac{
T a,b; //initializations
I frac(){
a=(T)0;b=(T)1;
}
I frac(RG T x){
a=x;b=(T)1;
}
I frac(RG T x,RG T y){
a=x;b=y;
this->init();
}
I void init(){
assert(b);
if(b<0)a=-a,b=-b;
this->reduction();
}
I frac&operator=(RG T x){
a=x;b=1;
return*this;
}
I double to_double(){
return(double)a/b;
} //arithmetic operation
I void reduction(){
RG T g=gcd(abs(a),b);
a/=g;b/=g;
}
I frac inv(){
assert(a);
return(frac){b,a};
}
I frac operator-(){
return(frac){-a,b};
}
I frac&operator++(){
a+=b;
return*this;
}
I frac&operator--(){
a-=b;
return*this;
}
I frac&operator+=(R x){
RG T g=gcd(b,x.b);
a=b/g*x.a+x.b/g*a;(b/=g)*=x.b;
this->reduction();
return*this;
}
I frac&operator-=(R x){
return*this+=-x;
}
I frac&operator*=(R x){
RG T g1=gcd(abs(a),x.b),g2=gcd(abs(x.a),b);
(a/=g1)*=x.a/g2;(b/=g2)*=x.b/g1;
return*this;
}
I frac&operator/=(R x){
return*this*x.inv();
}
I frac friend operator+(R x,R y){
RG T g=gcd(x.b,y.b);
x=(frac){x.b/g*y.a+y.b/g*x.a,x.b/g*y.b};
x.reduction();
return x;
}
I frac friend operator-(R x,R y){
return x+-y;
}
I frac friend operator*(R x,R y){
RG T g1=gcd(abs(x.a),y.b),g2=gcd(abs(y.a),x.b);
(x.a/=g1)*=y.a/g2;(x.b/=g2)*=y.b/g1;
return x;
}
I frac friend operator/(R x,R y){
return x*y.inv();
} //logic operations
I bool operator!(){
return!a;
}
I bool friend operator&&(R x,R y){
return x.a&&y.a;
}
I bool friend operator||(R x,R y){
return x.a||y.a;
}
I bool friend operator==(R x,R y){
return x.a==y.a&&x.b==y.b;
}
I bool friend operator!=(R x,R y){
return x.a!=y.a||x.b!=y.b;
}
#define logop(op) \
I bool friend operator op(R x,R y){ \
return (x+-y).a op 0; \
}
logop(<);logop(>);logop(<=);logop(>=);
#undef logop //input and output
I friend istream&operator>>(RG istream&is,R&x){
x=0;
static string s;is>>s;
RG int pos=s.find_first_of('/');
if(~pos){
s[pos]=' ';
istringstream(s)>>x.a>>x.b;
x.init();
}
else istringstream(s)>>x.a;
return is;
}
I friend ostream&operator<<(RG ostream&os,R x){
os<<x.a;
if(OutputFormat||x.b!=1)os<<'/'<<x.b;
return os;
}
};
#undef RG
#undef I
#undef R
#undef OutputFormat
}

分数模板(C++模板)的更多相关文章

  1. C++:类模板与模板类

    6.3 类模板和模板类 所谓类模板,实际上是建立一个通用类,其数据成员.成员函数的返回值类型和形参类型不具体指定,用一个虚拟的类型来代表.使用类模板定义对象时,系统会实参的类型来取代类模板中虚拟类型从 ...

  2. C++:函数模板与模板函数

    6.1 模板的概念 C++允许用同一个函数定义函数,这些函数的参数个数和参数类型不同.例如求最大值的max函数, int max(int x,int y) {       return (x>y ...

  3. C++ template学习一(函数模板和模板函数)

    函数模板和模板函数(1)函数模板函数模板可以用来创建一个通用的函数,以支持多种不同的形参,避免重载函数的函数体重复设计.它的最大特点是把函数使用的数据类型作为参数.函数模板的声明形式为:templat ...

  4. vs 2013下自定义ASP.net MVC 5/Web API 2 模板(T4 视图模板/控制器模板)

    vs 2013下自定义ASP.net MVC 5/Web API 2  模板(T4 视图模板/控制器模板): Customizing ASP.NET MVC 5/Web API 2 Scaffoldi ...

  5. C++ - 模板类模板成员函数(member function template)隐式处理(implicit)变化

    模板类模板成员函数(member function template)隐式处理(implicit)变化 本文地址: http://blog.csdn.net/caroline_wendy/articl ...

  6. .NET/ASP.NETMVC Model元数据、HtmlHelper、自定义模板、模板的装饰者模式(一)

    .NET/ASP.NETMVC Model元数据.HtmlHelper.自定义模板.模板的装饰者模式(一) 阅读目录: 1.开篇介绍 2.Model与View的使用关系(数据上下文DataContex ...

  7. C++类模板和模板类

    C++ 中有一个重要特性,那就是模板类型.类似于Objective-C中的泛型.C++通过类模板来实现泛型支持. 1 基础的类模板 类模板,可以定义相同的操作,拥有不同数据类型的成员属性. 通常使用t ...

  8. Xamarin XAML语言教程控件模板的模板绑定

    Xamarin XAML语言教程控件模板的模板绑定 控件模板的模板绑定 为了可以轻松更改控件模板中控件上的属性值,可以在控件模板中实现模板绑定功能.模板绑定允许控件模板中的控件将数据绑定到公共属性上. ...

  9. C++模板编程-模板基础重点

    模板基础 1.模板参数自动推导,如果是已知的参数类型与个数,这调用模板时可以不写类型. Cout<<max<int>(1,3);可以写为Cout<<max(1,3) ...

  10. Django——3 模板路径 模板变量 常用过滤器 静态文件的使用

    Django 模板路径 模板变量 过滤器 静态文件的加载 模板的路径,有两种方法来使用 设置一个总的templates在大项目外面,然后在sittings的TEMPLATES中声明 在每一个APP中创 ...

随机推荐

  1. BZOJ 2784 时间流逝

    BZOJ 2784 时间流逝 古典概率论... 可以发现由于能量圈数量限制,所以所构成的必定为树状结构(即便是转成最小能量圈和能量圈权值和之后存在重复状态,但是每个状态的含义不同,而且不能自身转移自身 ...

  2. 【LeetCode232】 Implement Queue using Stacks★

    1.题目描述 2.思路 思路简单,这里用一个图来举例说明: 3.java代码 public class MyQueue { Stack<Integer> stack1=new Stack& ...

  3. BZOJ1178 APIO2009 会议中心 贪心、倍增

    传送门 只有第一问就比较水了 每一次贪心地选择当前可以选择的所有线段中右端点最短的,排序之后扫一遍即可. 考虑第二问.按照编号从小到大考虑每一条线段是否能够被加入.假设当前选了一个区间集合\(T\), ...

  4. (转)Ubuntu init启动流程分析

    原文 upstart homepage 现行的Linux distros主流的有两种init方式:一种是广为流传的System V initialization,它来源于Unix并且至今仍被各种Lin ...

  5. CYJian的水题大赛

    实在没忍住就去打比赛了然后一耗就是一天 最后Rank19还是挺好的(要不是乐多赛不然炸飞),这是唯一一套在Luogu上号称水题大赛的而实际上真的是水题大赛的比赛 好了我们开始看题 T1 八百标兵奔北坡 ...

  6. Asp.Net Core基于Cookie实现同域单点登录(SSO)

    在同一个域名下有很多子系统 如:a.giant.com  b.giant.com   c.giant.com等 但是这些系统都是giant.com这个子域. 这样的情况就可以在不引用其它框架的情况下, ...

  7. [UWP 自定义控件]了解模板化控件(5):VisualState

    1. 功能需求 使用TemplatePart实现上篇文章的两个需求(Header为空时隐藏HeaderContentPresenter,鼠标没有放在控件上时HeaderContentPresent半透 ...

  8. ASS字幕制作

    虽然不常做视频,但正因为是偶尔用到,所以总是记不牢,特此笔记. Name 字体名称?Fontname 字体名称(\fn冬青黑体简体中文 W3)(\fnVogueSans)(例:\N{\fn冬青黑体简体 ...

  9. json中获取key值

    <script type="text/javascript"> getJson('age'); function getJson(key){ var jsonObj={ ...

  10. Centos6下关于系统用户密码规则-运维笔记

    随着linux使用的普遍,对于linux用户以及系统的安全要求越来越高,而用户密码复杂程度是系统安全性高低的首要体现.因此如何对linux下用户的密码进行规则限制,以保证用户必须使用复杂的密码,杜绝用 ...