kgcd ,fmod,fgcd
参考:NENU CS ACM模板made by tiankonguse 2.13 GCD
快速gcd:
位操作没学,真心不懂二进制,还是得学啊
code:
int kgcd(){
if(!a || !b)
return a?a:b;
if(!(a&) && !(b&))
return kgcd(a>>,b>>)<<;
if(!(b&))
return kgcd(a,b>>);
if(!(a&))
return kgcd(a>>,b);
return kgcd(b,a%b);
}
在说fgcd之前先说一下fmod函数吧
fmod:
原型:extern float fmod(float x, float y);
头文件:#include <math.h>
功能:计算x/y的余数
说明:返回x-n*y,使用codeblocks编译符号同x。n=[x/y](向离开零的方向取整)
举例:
int main(){
double x,y;
x=24.238;
y=;
printf("%lf\n",fmod(x,y));
}
运行结果是 4.238
fgcd:(实数的gcd)
模板:
#define eps 1e-8
double fgcd(double a,double b){
if(b > -eps && b < eps){
return a;
}
else{
return fgcd(b,fmod(a,b));
}
举例:
Apr 30,2014 codeforces
C. Ancient Berland Circus
题目大意:给出3个点,求最小面积的正多边形,使得这3个点为正多边形的顶点。
算法分析:
根据正多边形的性质,正多边形的每个顶点都在其外接圆上。
已知3个点,可以根据海伦公式求出三角形的面积S。然后根据正弦定理求出外接圆的半径R=abc/(4S),根据余弦定理求出三个圆心角。
求出三个圆心角的最大公约数A,则正多边形由2*pi/A个小三角形组成。
根据正弦定理求出每个小三角形的面积S0,则答案即为S0*2*pi/A。
Code:
#include <cstdio>
#include <cmath> using namespace std; const double pi=acos(-),eps=1e-; double x[],y[],a,b,c,A,B,C,p,S,R,alpha,S0,n; double fgcd(double a,double b){
if (fabs(b)<eps) return a;
return fgcd(b,fmod(a,b));
} int main(){
for (int i=;i<;++i) scanf("%lf%lf",&x[i],&y[i]);
a=sqrt((x[]-x[])*(x[]-x[])+(y[]-y[])*(y[]-y[]));
b=sqrt((x[]-x[])*(x[]-x[])+(y[]-y[])*(y[]-y[]));
c=sqrt((x[]-x[])*(x[]-x[])+(y[]-y[])*(y[]-y[]));
A=*acos((b*b+c*c-a*a)//b/c);
B=*acos((a*a+c*c-b*b)//a/c);
C=*pi-A-B;
p=(a+b+c)/;
S=sqrt(p*(p-a)*(p-b)*(p-c));
R=a*b*c//S;
alpha=fgcd(fgcd(A,B),C);
n=*pi/alpha;
S0=R*R*sin(alpha)/;
printf("%0.7lf\n",n*S0);
return ;
}
关于GCD的一些结论
1.有两个数p,q,gcd(p,q) = 1,则最大无法表示成px+qy(x >= 0 ,y >= 0)的数是pq-q-p.
2.区间内与n的gcd不小于m的数
输入m,n,求1-n之间中gcd(x,n) >= m 的x的个数。
找出N的所有大于等于M的因子(x1,x2,x3......xi),然后设k = N/xi.
下面只需找出小于k且与k互质的数。
因为:设y小于k且与k互质,那么gcd(y*xi,k*xi) = xi,(xi为k的因子,且xi大于等于M)。
kgcd ,fmod,fgcd的更多相关文章
- PHP求余函数fmod()
定义和用法 fmod() 函数返回除法的浮点数余数. 语法 fmod(x,y) 参数 描述 x 必需.一个数. y 必需.一个数. 说明 返回被除数(x)除以除数(y)所得的浮点数余数.余数(r)的定 ...
- C语言fmod()函数:对浮点数取模(求余)
头文件:#include <math.h> fmod() 用来对浮点数进行取模(求余),其原型为: double fmod (double x); 设返回值为 ret,那么 x = ...
- 基于cocos2d-x的Android游戏中使用fmod音频引擎
cocos2d-x的音频引擎是cocosDenshion, 它的Android版比较弱, 只能播放一个背景音乐和些许音效, 如果要实现稍微复杂一点的音频播放, 比如同时播放几个音轨就不能了. 这一点远 ...
- [MetaHook] Quake FMOD function
QFMOD.h #ifndef QFMOD_H #define QFMOD_H #include "fmod.h" extern FMOD_RESULT (F_API *qFMOD ...
- FMOD在Android玩音响系统的抖动问题
1. 基本介绍 在Android升级系统Android4.4之后,发现FMOD在Android音会出现抖动.导致声音不正常.边赫赫有名的"极品飞车"都有问题. 经查验,是FMOD的 ...
- fmod函数和modf函数
最近从博客上看到了一个fmod函数,结果又蹦出来一个modf函数 fmod函数: 头文件:#include<math.h> C库函数... fmod()用来对浮点数进行取模(求余),原型为 ...
- fmod()函数 (对浮点数取模)
头文件:#include <math.h> fmod() 用来对浮点数进行取模(求余),其原型为: double fmod (double x); 设返回值为 ret,那么 x = ...
- Fmod使用总结
1.查询相关文档的地址 http://www.fmod.org/forum/viewtopic.php?f=7&t=15762
- FMOD变声如何捕获并存储处理音效之后的数据
类似AVAudioEngine的功能,一个Engine可以将N个connect连接(串联和并联)在一起,这样来实现多个输入源,多层处理效果的混合输出.实现这个所需功能也是通过这样的方案来实现的.也就是 ...
随机推荐
- gnuWin32-mini-2016.10.30
2016-10-28 04:48 1,017,856 awk.exe ver 4.1.4 2016-10-29 00:26 77,312 bc.exe ver 1.06 2016-10-30 01:4 ...
- DIV+CSS中标签dl dt dd常用的用法
转自:http://smallpig301.blog.163.com/blog/static/9986093201010262499229/ < dl>< /dl>用来创建一个 ...
- JSFiddle
<script async src="//jsfiddle.net/980355088/k0u1qjm6/embed/"></script>
- WebSocket介绍和一个简单的聊天室
WebSocket是什么呢? WebSocket一种在单个 TCP 连接上进行全双工通讯的协议.WebSocket通信协议于2011年被IETF定为标准RFC 6455,并被RFC7936所补充规范, ...
- UIAlertController使用
// 将UIAlertController模态出来 相当于UIAlertView show 的方法// 初始化一个一个UIAlertController // 参数preferredStyle: ...
- tushare
tushare TuShare是一个免费.开源的python财经数据接口包.主要实现对股票等金融数据从数据采集.清洗加工 到 数据存储的过程,能够为金融分析人员提供快速.整洁.和多样的便于分析的数据, ...
- 病毒四度升级:安天AVL Team揭露一例跨期两年的电信诈骗进化史
自2014年9月起,安天AVL移动安全团队持续检测到一类基于Android移动平台的间谍类病毒,病毒样本大多伪装成名为"最高人民检察院"的应用.经过反编译逆向分析以及长期的跟踪调查 ...
- AndroidStudio导入项目出现Your project path contains non-ASCII characters错误
Your project path contains non-ASCII characters. This will most likely cause the build to fail on Wi ...
- Android-Spinner [使用C# And Java实现]
效果如下: C#实现代码 using Android.App; using Android.OS; using Android.Widget; namespace SpinnerDemo { [Act ...
- AOJ 0121: Seven Puzzle【BFS】
From: AOJ 0121 思路:与前几题的bfs不同,这次的bfs没有明确的移动对象,看似任意一个数都可以当成对象移动.这时我们只需要抓住一个格子就行,比如我们把0作为移动对象,那么0在地图中漫游 ...