コード例 #1
0
ファイル: 39.cpp プロジェクト: 253627764/algorithm
 void FindNumsAppearOnce(vector<int> data,int* num1,int *num2) {
 	if(data.size()<2) return;
     int size=data.size();
     int temp=0;
     for(int i=0;i<size;i++)//对数组中每个数字做异或
         temp=temp^data[i];
     if(temp==0) return;
     int index=0;
     while((temp&1)==0)//在整数temp的二进制表示中找到最右边是1的位
     {
         temp=temp>>1;
         ++index;
     }
     //根据数组的倒数第index位是否为1,将数组划分为两个子数组,并分别对两个子数组进行求异或,得到num1和num2  
     *num1=*num2=0;
     for(int i=0;i<size;i++)
     {
         if(IsBit(data[i],index))
             *num1^=data[i];
         else
             *num2^=data[i];
     }
 }
コード例 #2
0
int main(void)
{
      char array[64];

      memset(array, '\0', sizeof(array));

      BitOn(array, 5);
      BitOn(array, 12);
      BitOn(array, 500);

      if (IsBit(array, 5) && IsBit(array, 12) && IsBit(array, 500))
            puts("These functions seem to work!");
      else  puts("Something's broken here!");

      BitFlip(array, 12);
      BitOff(array, 5);

      if (!IsBit(array, 5) && !IsBit(array, 12) && IsBit(array, 500))
            puts("These functions still seem to work!");
      else  puts("Something's broken here!");
      return 0;
}