📌  相关文章
📜  C#| BitArray元素之间的按位异或运算

📅  最后修改于: 2021-05-29 21:29:02             🧑  作者: Mango

BitArray类管理一个紧凑的位值数组,这些值表示为布尔值,其中true表示该位打开,1 ,false表示该位关闭,0 。此类包含在System.Collections命名空间中。
BitArray.Xor(BitArray)方法用于在当前BitArray对象的元素与指定数组中的相应元素之间执行按位异或运算。
当前的BitArray对象将被修改以存储按位异或运算的结果。

特性:

  • BitArray类是一个集合类,其中容量始终与计数相同。
  • 通过增加Length属性将元素添加到BitArray中。
  • 通过减小Length属性来删除元素。
  • 可以使用整数索引访问此集合中的元素。此集合中的索引从零开始。

句法:

public System.Collections.BitArray Xor (System.Collections.BitArray value);

在此, value是用于执行按位异或运算的数组。

返回值:它返回一个包含按位异或运算结果的数组,该数组是对当前BitArray对象的引用。

例外情况:

  • ArgumentNullException:如果该值为null。
  • ArgumentException:如果该值和当前BitArray不具有相同数量的元素。

下面给出了一些示例,以更好地理解实现:

范例1:

// C# code to perform the bitwise exclusive 
// OR operation between BitArray
using System;
using System.Collections;
  
class GFG {
  
    // Driver code
    public static void Main()
    {
  
        // Creating a BitArray
        BitArray myBitArr1 = new BitArray(4);
  
        // Creating a BitArray
        BitArray myBitArr2 = new BitArray(4);
  
        // Initializing values in myBitArr1
        myBitArr1[0] = false;
        myBitArr1[1] = false;
        myBitArr1[2] = true;
        myBitArr1[3] = true;
  
        // Initializing values in myBitArr2
        myBitArr2[0] = false;
        myBitArr2[1] = true;
        myBitArr2[2] = false;
        myBitArr2[3] = true;
  
        // function calling
        PrintValues(myBitArr1.Xor(myBitArr2));
    }
  
    // Displaying the result
    public static void PrintValues(IEnumerable myList)
    {
        foreach(Object obj in myList)
        {
            Console.WriteLine(obj);
        }
    }
}
输出:
False
True
True
False

范例2:

// C# code to perform the bitwise exclusive 
// OR operation between BitArray
using System;
using System.Collections;
  
class GFG {
  
    // Driver code
    public static void Main()
    {
  
        // Creating a BitArray
        BitArray myBitArr1 = new BitArray(4);
  
        // Creating a BitArray
        BitArray myBitArr2 = new BitArray(6);
  
        // Initializing values in myBitArr1
        myBitArr1[0] = false;
        myBitArr1[1] = false;
        myBitArr1[2] = true;
        myBitArr1[3] = true;
  
        // Initializing values in myBitArr2
        myBitArr2[0] = false;
        myBitArr2[1] = true;
        myBitArr2[2] = false;
        myBitArr2[3] = true;
        myBitArr2[4] = true;
        myBitArr2[5] = true;
  
        // function calling
        // This should raise "ArgumentException"
        // as array lengths are not same
        PrintValues(myBitArr1.Xor(myBitArr2));
    }
  
    // Displaying the result
    public static void PrintValues(IEnumerable myList)
    {
        foreach(Object obj in myList)
        {
            Console.WriteLine(obj);
        }
    }
}

运行时错误:

笔记:

  • 按位异或操作返回true,如果只有一个操作数为,返回false如果两个操作数具有相同的布尔值。
  • 此方法是O(n)运算,其中n是Count。

参考:

  • https://docs.microsoft.com/zh-cn/dotnet/api/system.collections.bitarray.xor?view=netframework-4.7.2