您好,欢迎访问一九零五行业门户网

使用 C# 在没有任何内置函数的情况下查找排序数组中缺失的数字有哪些不同方法?

共有以下三种方法 -
第一种方法
使用公式n(n+1)/2 计算元素数量,然后需要从数组中的元素中减去。
在第二种方法中
创建一个新数组,遍历整个数组,将找到的数字设为 false。
在第三种方法中强>
使用异或运算。这给出了缺失的数字。
示例 实时演示
using system;namespace consoleapplication{ public class arrays{ public int missingnumber1(int[] arr){ int totalcount = 0; for (int i = 0; i < arr.length; i++){ totalcount += arr[i]; } int count = (arr.length * (arr.length + 1)) / 2; return count - totalcount; } public int missingnumber2(int[] arr){ bool[] temparray = new bool[arr.length + 1]; int element = -1; for (int i = 0; i < arr.length; i++){ int index = arr[i]; temparray[index] = true; } for (int i = 0; i < temparray.length; i++){ if (temparray[i] == false){ element = i; break; } } return element; } public int missingnumber3(int[] arr){ int result = 1; for (int i = 0; i < arr.length; i++){ result = result ^ arr[i]; } return result; } } class program{ static void main(string[] args){ arrays a = new arrays(); int[] arr = { 0, 1, 3, 4, 5 }; console.writeline(a.missingnumber1(arr)); console.writeline(a.missingnumber2(arr)); console.writeline(a.missingnumber3(arr)); console.readline(); } }}
输出222
以上就是使用 c# 在没有任何内置函数的情况下查找排序数组中缺失的数字有哪些不同方法?的详细内容。
其它类似信息

推荐信息