方法一:將一個int類型整數不斷加1,加到最大值,再加1,就變成負值(最小值)
最大值就是除最高位外,其余位都為1,-1即是所有位全部是1,右移1位后最高位變0
最小值即是最高位為1,其余位為0,所以最大值+1之后就變成了最小值
//#include <stdio.h> #include <iostream> //#include <limits.h> using namespace std; int main(){ int i = 0, min, max; while(1){ if(i+1<=0){ max = i; min = i+1; break; } i++; } cout << "min is " << min <<endl; cout << "max is " << max << endl; getchar(); return 0; }
方法二:利用標准頭文件limits.h,該文件包含一些很有用的常量,它們定義了各種類型所能容納的值,其中int類型最大值最小值的預定義為
#define INT_MAX 2147483647
#define INT_MIN (-INT_MAX-1)
所以可以利用此頭文件打印int類型整數的最小值和最大值。
//#include <stdio.h> #include <iostream> #include <limits.h> using namespace std; int main(){ cout << "最小值是:" << INT_MIN << endl; cout << "最大值是:" << INT_MAX << endl; getchar(); return 0; }
方法三:C++模板numeric_limits(對模板不熟悉啊)可以參考:
http://blog.163.com/wujiaxing009@126/blog/static/7198839920124135147911/
代碼:
#include <iostream> #include <limits> using namespace std; int main(){ cout<<(numeric_limits<int>::max)()<<endl; cout<<(numeric_limits<int>::min)()<<endl; cout<<(numeric_limits<size_t>::max)()<<endl; cout<<(numeric_limits<size_t>::min)()<<endl; cout<<(numeric_limits<float>::max)()<<endl; cout<<(numeric_limits<float>::min)()<<endl; cout<<(numeric_limits<double>::max)()<<endl; cout<<(numeric_limits<double>::min)()<<endl; getchar(); return 0; }
以上是在網上看到的三種方法,學習學習。