关于数论的一些知识点,慢慢积攒

数论的东西太多了,决定把一些遇到的定理在这里整理一下

L(x) 求的是 LCM(1,2,3.....x)
LCM  求最小公倍数
L(1) = 1

L(x+1) = { L(x) * p    if x+1 is a perfect power of prime p
         { L(x)        otherwise
PI的定义方式
const double PI = acos(-1); 
欧拉函数(求1~n与n互质的数的个数)
Φ(n) = n*(1 - 1/p1)*(1 - 1/p2)....(1 - 1/pn) pn is prime
关于 ax + by = 1 的必要条件是 gcd(a,b) = 1的简单证明
假设a,b的最大公约数为m,如果方程ax+by=1有解,那么方程(a/m)x+(b/m)y=1/m.有整数解。
显然不成立(a/m, b/m 是整数,整数加整数不等于小于1的数),所以假设不成立
关于取整的两个函数
#include <math.h> double floor(double x); 
float floorf(float x); 
long double floorl(long double x);

double floor(double x);

double ceil(double x);

使用floor函数。floor(x)返回的是小于或等于x的最大整数。
如:     floor(10.5) == 10    floor(-10.5) == -11


使用ceil函数。ceil(x)返回的是大于x的最小整数。
如:     ceil(10.5) == 11    ceil(-10.5) ==-10

    
floor()是向负无穷大舍入,floor(-10.5) == -11;
ceil()是向正无穷大舍入,ceil(-10.5) == -10



不得不说点:/ % 四舍五入 向上取整(ceil()) 向下取整(floor)
 1. /

    //Test "/"
    cout << "Test \"/\"!" << endl;
    cout << "7   / 2   = " << 7/2 << endl;      ///3
    cout << "7   / 2.0 = " << 7/2.0 << endl;    ///3.5
    cout << "7.0 / 2   = " << 7.0/2 << endl;    ///3.5
    cout << "7.0 / 2.0 = " << 7.0/2.0 << endl; ///3.5
    cout << "7   / 3   = " << 7/3 << endl;      ///2
    cout << endl;

2. %
    ///Test "%"
    cout << "Test \"%\"!" << endl;
    cout << "9   % 3   = " << 9%3 << endl;      ///0
    cout << "9   % 4   = " << 9%4 << endl;      ///1
    ///cout << "9.0 % 3   = " << 9.0%3 << endl;
    ///cout << "9   % 3.0 = " << 9%3.0 << endl;
    cout << endl;

3. 四舍五入
    ///Test round()
    cout << "Test \"四舍五入\"!" << endl;
    double dRoundA = 1.4;
    double dRoundB = 1.6;
    double dRoundLowA = -1.4;
    double dRoundLowB = -1.6;
    double dRoundLowC = 0.0;
    cout << dRoundA << " = " << RoundEx(dRoundA) << endl;         ///1
    cout << dRoundB << " = " << RoundEx(dRoundB) << endl;         ///2
    cout << dRoundLowA << " = " << RoundEx(dRoundLowA) << endl;   ///-1
    cout << dRoundLowB << " = " << RoundEx(dRoundLowB) << endl;   ///-2
    cout << dRoundLowC << " = " << RoundEx(dRoundLowC) << endl;   ///0
    cout << endl;

double RoundEx(const double& dInput)
{
    double dIn = dInput;
    if (dInput >= 0.0)    ///???
    {
        return int(dIn + 0.5);
    } 
    else
    {
        return int(dIn - 0.5);
    }
}

4. ceil() 向上取整
    ///Test ceil() 向上取整
    cout << "Test ceil() 向上取整!" << endl; 
    cout << "ceil 1.2 = " << ceil(1.2) << endl;      ///2
    cout << "ceil 1.8 = " << ceil(1.8) << endl;      ///2
    cout << "ceil -1.2 = " << ceil(-1.2) << endl;    ///-1
    cout << "ceil -1.8 = " << ceil(-1.8) << endl;    ///-1
    cout << "ceil 0.0 = " << ceil(0.0) << endl;      ///0
    cout << endl;

5. floor() 向下取整
    ///Test floor() 向下取整
    cout << "Test floor() 向下取整!" << endl;
    cout << "floor 1.2 = " << floor(1.2) << endl;    ///1
    cout << "floor 1.8 = " << floor(1.8) << endl;    ///1
    cout << "floor -1.2 = " << floor(-1.2) << endl; ///-2
    cout << "floor -1.8 = " << floor(-1.8) << endl; ///-2
    cout << "floor 0.0 = " << floor(0.0) << endl;    ///0
    cout << endl;
拓扑排序
如果in[](入度数组)中存在两个以上的in[x] == 0,该拓扑排序的顺序无法判断
如果in[]判定完毕后,还存在in[x] != 0,该拓扑排序中存在冲突,即存在环



发布了69 篇原创文章 · 获赞 58 · 访问量 5万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章