一. -nan(ind):
nan:not a number:无法得到一个数字
ind:indeterminate: 不确定的
可能情况:
1. 分母为零
2. 对负数开平方
3. 有些编译器在对无穷大无穷小的计算时也会出现此类情况。
二. 重载运算符:
1. 实质:函数重载或函数多态,让人能够用同名的函数来完成不同的基本操作。
2. 形式:operatorp ( argument-list ) // 'p'为要重载的运算符
3. 规则:
(1)重载后的操作对象必须至少有一个是用户定义的类型
(2)使用运算符不能违反运算符原来的句法规则
如:
int index;
%index; //这样不被允许
(3)不能修改运算符原来的优先级
(4)不能创建一个新的运算符,如:不能定义operator**()来求幂
(5)不能进行重载的运算符:成员运算符,作用于3运算符,条件运算符,sizeof运算符,typeid(一个RTTI运算符),const_cast , dynamic_cast , reinterpret_cast , static_cast强制类型转换运算符。
(6)大多数运算符可以通过成员函数和非成员函数进行重载,但是下面四种函数只能通过成员函数进行重载:
=赋值运算符,()函数调用运算符,[ ] 下标运算符,->通过指针访问类函数成员的运算符
4. 注意:
(1)一般,单目运算符重载为类的成员函数,双目运算符重载为类的友元函数。
(2)双目运算符不能将 =,(),[ ] , -> 重载为类的友元函数。
(3)如果运算符的第一次操作要求为隐式转换,则必须为友元函数。
(4)当最左边的要求为类对象,而右边的是一个内置类型,则要为友元函数。
三. 结构体排序
sort(a,a+n,cmp)// a是数组起始指针,a+n是数组尾指针(左闭右开),cmp是排序规则(默认升序)
方法一:定义cmp函数
#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
struct student
{
string name; //比char好的地方是不用定义大小
int age;
};
int cmp(const student &s1,const student &s2)
{
if(s1.name==s2.name)
return s1.age<s2.age;
return s1.name<s2.name; //按姓名从小到大排序,姓名一样,按年龄从小到大排序
}
int main()
{
int a[100];
sort(a,a+7);
sort(a,a+7,less<int>());
sort(a,a+7,greater<int>());
student s[100];
sort(s,s+3,cmp); //定义域为 [0,3)
return 0;
}
方法二:结构体内重载
#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
struct student
{
string name;
int age;
bool operator<(const student&s)const
{
if(name==s.name)
return age<s.age;
return name<s.name;
}
};
int main()
{
int a[100];
sort(a,a+7);
sort(a,a+7,less<int>());
sort(a,a+7,greater<int>());
student s[100];
sort(s,s+3); //定义域为 [0,3)
return 0;
}