源于无聊, 又再看了复习了下"不用临时变量进行整型变量交换"

两种流行方法:
(1) 加减减
1 void AsExchang(int &x, int &y)
2 {
3      x = x + y;
4      y = x - y;
5      x = x - y;
6 }
7 

(2) 异或
1 void XorExchang(int &x, int &y)
2 {
3      x = x ^ y;
4      y = x ^ y;
5      x = x ^ y;
6 }

两种方法, 都可以认识是密码学的一部分吧, 只是用加减法来加密, 幼稚且缺乏安全性而已.
当然, 异或法在现实中也得变种才能实际应用

一开始傻傻地联想到方法一是否存在越界问题... //基础知识瞬间薄弱化...
系统底层的实现居然一时间忘记了...

联想到如何确认一个类型能表示的最大最小值
(1)
所以想到的用sizeof运算符, 判断类型的位数, 然后笨笨地左移右移操作进行计算
int getMaxInt()
{
    
int iBase= 1;
    
const int IntSize = sizeof(int* 8;

    
//int是有符号数, 最左边一位是符号位
    
//so
    for(int i = 1; i < IntSize - 1 ; i++ )
    {
        iBase 
= (iBase << i) + 1;
    }

    
return iBase; 
}
好笨的方法...
很没效率

(2)
用强制转换吧, (int)0x*,
*是什么, 0x7fffffff
恶心-_-||, 我一开始又4个f了, 一个f才4位吧...

(3)
还有用bitset, bitsit有to_ulong方法, 凑合着用

(4)
climits的 INT_MAX
在cplusplus.com上面的reference是显示
INT_MAX  Maximum value for an object of type int
 = 32767
被他的图表骗了

VC6版本的头文件里面是用
#define INT_MAX  2147483647 
直接定义的
查看cywin里面的头文件
也差不多..
#define __INT_MAX__ 2147483647
#define INT_MAX __INT_MAX__


(5)
C++标准方法..
//直接贴过来了
//前面有说明说numeric_limits<int>::max()等于INT_MAX
//... 只是封装了模板而已
 1 // numeric_limits example
 2 #include <iostream>
 3 #include <limits>
 4 using namespace std;
 5 
 6 int main () {
 7   cout << boolalpha;
 8   cout << "Minimum value for int: " << numeric_limits<int>::min() << endl;
 9   cout << "Maximum value for int: " << numeric_limits<int>::max() << endl;
10   cout << "int is signed: " << numeric_limits<int>::is_signed << endl;
11   cout << "Non-sign bits in int: " << numeric_limits<int>::digits << endl;
12   cout << "int has infinity: " << numeric_limits<int>::has_infinity << endl;
13   return 0;
14 }



没去找高手们的奇招, 浪浪荡荡又消费了不少时间...
继续潜修去


只有注册用户登录后才能发表评论。
网站导航: 博客园   IT新闻   BlogJava   博问   Chat2DB   管理


Copyright © 蓝尘