尝试贴一段代码

尝试贴一段代码,看看代码高亮功能能不能正常工作。

//This is a project made by MtZero
//Start at 2015/12/11 21:00
#include<iostream>
#include<string>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<cstdlib>
#include<vector>
#include<stack>
#include<sstream>
#include<algorithm>
#include<list>
using namespace std;
#ifndef _CODE_
#define _CODE_                                  0        //只是个标记,无他用
/*错误代码*/
#define CORRECT                                 0        //无错误
#define CONST_NOT_VALID                         1        //常数不合法
#define DIV_0                                   2        //除以0
#define FORMAT_ERROR                            3        //格式错误
#define STACK_ERROR                             4        //堆栈错误
#define MATH_ERROR                              5        //数学错误
#define OPERATION_ERROR                         6        //操作符错误
/*操作符代码*/
#define _OP_CONST                               0        //常数
#define _OP_PLUS                                1
#define _OP_MINUS                               2
#define _OP_MULTI                               3
#define _OP_DIV                                 4
#define _OP_POW                                 5        //乘方
#define _OP_EXT                                 6        //开方
#define _OP_LOG                                 7        //对数
#define _OP_LOG10                               8        //常用对数
#define _OP_LN                                  9        //自然对数
#define _OP_MOD                                 10       //取模
#define _OP_TRUNC                               11       //截取
#define _OP_ROUND                               12       //四舍五入
/*限制*/
#define BIGNUM_MAX_LEN                          65500
#define STACK_MAX_DEPTH                         250
/*常数*/
#define PI                                      3.1415926535897932385
#define N_BASE                                  2.7182818284590452354
/*模式*/
#define _MODE_HI_PRE                            1        //高精度计算模式
#define _MODE_CALC                              2        //浮点计算模式
#define _MODE_PROG                              3        //程序员计算模式
#define _MODE_COMPLEX                           4
#define _MODE_MATRIX                            5
#define _MODE_VECTOR                            6
#define _MODE_EQUATION                          7
#endif
int MODE = 1;
class BigNum {
private:
vector<short> num;
int   point;                            //小数点位置
bool  isPos;                            //是否为非负数
int   equalTo(string s);
int   isBigger(BigNum &bn);             //忽视符号判断大小
int   accessDig(int n, int &size);      //获取大小为size的大数的第n位(从左到右)
BigNum plus(BigNum &bn);
BigNum minus(BigNum &bn);
public:
BigNum();
BigNum(string s);
BigNum DIV(BigNum &bn);                 //整数除法
int iPart();                            //返回整数部分的长度
int dPart();                            //返回小数部分的长度
/*操作符重载*/
BigNum    operator +  (BigNum &bn);
BigNum    operator -  (BigNum &bn);
BigNum    operator *  (BigNum &bn);
BigNum    operator /  (BigNum &bn);     //带小数除法
BigNum    operator %  (BigNum &bn);
BigNum    operator += (BigNum &bn);
BigNum    operator -= (BigNum &bn);
BigNum    operator *= (BigNum &bn);
BigNum    operator /= (BigNum &bn);
BigNum    operator %= (BigNum &bn);
void      operator =  (string bn);
void      operator =  (long long sn);
void      operator =  (BigNum &bn);
//istream&  operator >> (istream &in);       //HOW?
//ostream&  operator << (ostream &out);
bool      operator >  (BigNum &bn);
bool      operator <  (BigNum &bn);
bool      operator == (BigNum &bn);
bool      operator >= (BigNum &bn);
bool      operator <= (BigNum &bn);
friend ostream &operator <<(ostream &stream, string s);
friend istream &operator >>(istream &stream, string s);
/*
friend ostream &operator<<(ostream &stream, Rational rational);
friend istream &operator>>(istream &stream, Rational &rational);
*/
/*打印大数*/
//void echo(int dec = 0);
/*
BigNum pow(BigNum bn);
BigNum ext(BigNum bn);               //开方
BigNum log(BigNum bn, BigNum base);
*/
};
int BigNum::iPart() {                    //返回整数部分的长度
return this->point;
}
int BigNum::dPart() {                    //返回小数部分的长度
return this->num.size() - this->point;
}
int BigNum::equalTo(string s) {
/*判断输入的参数是否合法*/
int pcnt = 0;
int len = s.length();
/*判断是否为负数*/
if (s[0] == '-') {
isPos = false;
s.erase(0, 1);
}
else isPos = true;
/*检查非法字符*/
if (s[0] != '.' && (s[0]<'0' || s[0]>'9')) {
return CONST_NOT_VALID;
}
/*查找是否有小数点*/
int pPos = -1;
pPos = s.find('.');
if (pPos > -1) {
this->point = pPos;
s.erase(s.begin() + pPos);
}
/*将纯数串写入vector容器*/
len = s.length();
this->num.clear();
for (int i = 0; i < len; i++) {
this->num.push_back(s[len - i - 1] - 48);    //vector容器的低位相当于大数字的低位
}
/*如果没有找到小数点*/
if (pPos == -1) {
point = this->num.size();
}
return CORRECT;
}
BigNum::BigNum(string s) {
equalTo(s);
}
BigNum::BigNum() {
equalTo("0");
}
BigNum BigNum::plus(BigNum &bn) {                    //忽视符号的加法 UNDEBUGGED
BigNum ans;
int anslen = max(this->iPart(), bn.iPart()) + max(this->dPart(), bn.dPart()) + 1;
int thisSize = this->num.size();
int bnSize = bn.num.size();
int ansDPart = max(this->dPart(), bn.dPart());
ans.point = anslen - ansDPart;
/*用以对齐小数点*/
int thisDiff = ans.dPart() - this->dPart();
int bnDiff = ans.dPart() - bn.dPart();
ans.num.clear();
ans.num.push_back(this->accessDig(0 - thisDiff, thisSize) + bn.accessDig(0 - bnDiff, bnSize));
for (int i = 1; i < anslen; i++) {
ans.num.push_back(this->accessDig(i - thisDiff, thisSize) + bn.accessDig(i - bnDiff, bnSize) + ans.num[i - 1] / 10);
ans.num[i - 1] %= 10;
}
if (ans.num[anslen - 1] == 0) ans.num.erase(ans.num.begin() + anslen - 1);
return ans;
}
BigNum BigNum::minus(BigNum &bn) {                   //忽视符号的减法(大减小) 未完成
BigNum ans;
int anslen = max(this->iPart(), bn.iPart()) + max(this->dPart(), bn.dPart()) + 1;
int thisSize = this->num.size();
int bnSize = bn.num.size();
return ans;
}
void BigNum::operator =(string bn) {
equalTo(bn);
}
void BigNum::operator =(long long sn) {
string s;
stringstream ss;
ss << sn;
s = ss.str();
this->operator =(s);
}
void BigNum::operator =(BigNum &bn) {
this->num = bn.num;
this->point = bn.point;
this->isPos = bn.isPos;
}
int BigNum::accessDig(int n, int &size) {
if (n >= size || n < 0) return 0;
else return this->num[n];
}
int BigNum::isBigger(BigNum &bn) {          //大于 -> 1; 等于 -> 0; 小于 -> -1
if (this->point > bn.point) return 1;
if (this->point < bn.point) return -1;
/*以下三行获取两个大数字的位数以及较大的那个位数*/
int thisSize = this->num.size();
int bnSize = bn.num.size();
int maxSize = max(thisSize, bnSize);
int diff = thisSize - bnSize;           //大数位数之差
for (int i = 1; i <= maxSize; i++) {
int thisDig = this->accessDig(thisSize - i, thisSize);
int bnDig = bn.accessDig(bnSize - i, bnSize);
if (thisDig > bnDig) return 1;
if (thisDig < bnDig) return -1;
}
return 0;
}
bool BigNum::operator >(BigNum &bn) {       //UNDEBUGGED
if (this->isPos&&!bn.isPos) {
return true;
}
else if (!this->isPos&&bn.isPos) {
return false;
}
else if (this->isPos&&bn.isPos) {
return this->isBigger(bn) == 1;
}
else return !(this->isBigger(bn) == -1);
}
bool BigNum::operator <(BigNum &bn) {       //UNDEBUGGED
if (this->isPos&&!bn.isPos) {
return false;
}
else if (!this->isPos&&bn.isPos) {
return true;
}
else if (this->isPos&&bn.isPos) {
return this->isBigger(bn) == -1;
}
else return this->isBigger(bn) == 1;
}
bool BigNum::operator >=(BigNum &bn) {      //UNDEBUGGED
return !this->operator <(bn);
}
bool BigNum::operator <=(BigNum &bn) {      //UNDEBUGGED
return !this->operator >(bn);
}
bool BigNum::operator ==(BigNum &bn) {      //UNDEBUGGED
if (this->isPos != bn.isPos) return false;
if (this->point != bn.point) return false;
int thisSize = this->num.size();
int bnSize = bn.num.size();
int maxSize = max(thisSize, bnSize);
for (int i = 1; i <= maxSize; i++) {
if (this->accessDig(thisSize - i, thisSize) != bn.accessDig(bnSize - i, bnSize)) return false;
}
return true;
}
/*
istream& BigNum::operator >>(istream &in) {    //HOW?
string s;
in >> s;
equalTo(s);
return in;
}
ostream& BigNum::operator <<(ostream &out) {
return out;
}
*/
/*iostream参考
istream& operator >> (istream &in, bign &x)
{
string s;
in >> s;
x = s.c_str();
return in;
}
ostream& operator << (ostream &out, const bign &x)
{
out << x.str();
return out;
}
friend ostream &operator<<(ostream &stream, Rational rational);
friend istream &operator>>(istream &stream, Rational &rational);
*/
struct bnNode {                                  //高精度节点
BigNum bn;                                   //高精度整数
int op;                                      //操作符代码
};
struct Node {                                    //浮点数节点
long double num;                             //浮点数
int op;                                      //操作符代码
};
vector<bnNode> bnQue;                            //高精度队列
vector<Node> que;                                //浮点数队列
/*DEBUG AREA*/
BigNum b("3.1415926"), c("3.1415927"), e("3.141592600");
/*DEBUG AREA END*/
int main() {
/*DEBUG AREA*/
string s;
long long d = 9873457;
//cin >> s;
//b = s;
//c = b;
//c = d;
//b = "3.1415926";
//c = "3.1415927";
//e = "3.141592600";
cout << (b < c) << endl;
cout << (b > c) << endl;
cout << (b <= c) << endl;
cout << (b >= c) << endl;
cout << (b < e) << endl;
cout << (b > e) << endl;
cout << (b <= e) << endl;
cout << (b >= e) << endl;
cout << (b == e) << endl;
//cin >> c;
//cout << c;
/*DEBUG AREA END*/
return 0;
}

 

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注