作者:he小任a | 来源:互联网 | 2023-10-16 21:28
1、用宏定义写出swap(x,y)答#defineswap(x,y)xx+y;yx-y;xx-y;2、数组a[N],存放了1至N-1个数,其中某个数重复一次。写一个函数,找出被重复
1、 用宏定义写出swap(x,y) 答
#define swap(x, y) x = x + y; y = x - y;x = x - y;
2、数组a[N],存放了1至N-1个数,其中某个数重复一次。写一个函数,找出被重复的数字.时间复杂度必须为o(N)函数原型:int do_dup(int a[],int N) 答:
int do_dup(int a[],int N) //未经调试 { int sun = 0; int sum2; for(int i=0;i { Sum+=a[i]; } Sum2 = (1+N-1)*N/2; Return (sum-sum2); }
3 一语句实现x是否为2的若干次幂的判断 答:方法1)int i = 512; cout < 2)return (x>>N==1); 4.unsigned int intvert(unsigned int x,int p,int n)实现对x的进行转换,p为起始转化位,n为需要转换的长度,假设起始点在右边.如x=0b0001 0001,p=4,n=3转换后x=0b0110 0001 答:unsigned int intvert(unsigned int x,int p,int n) //假定p=4,n=3 { unsigned int _t = 0; unsigned int _a = 1; for(int i = 0; i { _t |= _a; //位或 _a = _a <<1; } _t = _t <
x ^= _t; /异或,将原来的位取反
return x;
}