C#数组查找元素

2022/4/14 9:12:43

本文主要是介绍C#数组查找元素,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

包括通过查找数组中某个元素的下标(第⼀次出现时的下标,最后⼀次出现时的下标),查找某个数组中是否有某元素。

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace study1_repeat
{
class Program
{
static void Main(string[] args)
{
int[] intArr = { 1, 2, 3, 4, 5, 6, 3, 5, 3 };
int value1 = 3;
int value2 = 8;
int first1 = Array.IndexOf(intArr, value1);
//查找value1第⼀次出现的索引
int first2 = Array.IndexOf(intArr, value2);
int end1 = Array.LastIndexOf(intArr, value1);
int end2 = Array.LastIndexOf(intArr, value2);
//查找最后⼀次出现的索引
int result1 = Array.BinarySearch(intArr, value1);
int result2 = Array.BinarySearch(intArr, value2);
//查找value1第⼀次出现的索引,这个⽅法采⽤⼆分法搜索。
bool contain1;
bool contain2;
//定义两个布尔值。
if (((System.Collections.IList)intArr).Contains(value1))
{
contain1 = true;
}
else {
contain1 = false;
}
if (((System.Collections.IList)intArr).Contains(value2)) {
contain2 = true;
}
else
{
contain2 = false;
}
//将结果输出出来
Console.WriteLine("数组中的⼀个{0}的下标为:{1}", value1, first1);
Console.WriteLine("数组中的⼀个{0}的下标为:{1}", value2, first2);
Console.WriteLine("数组中的最后⼀个{0}的下标为:{1}", value1, end1);
Console.WriteLine("数组中的最后⼀个{0}的下标为:{1}", value2, end2);
Console.WriteLine("数组中{0}的下标为:{1}", value1, result1);
Console.WriteLine("数组中{0}的下标为:{1}", value2, result2);
if (contain1)
{
Console.WriteLine("数组中包含{0}", value1);
}
else {
Console.WriteLine("数组中不包含{0}", value1);
}
if (contain2)
{Console.WriteLine("数组中包含{0}", value2);
}
else
{
Console.WriteLine("数组中不包含{0}", value2);
}
Console.ReadLine();
}
}
}

  

Array.IndexOf(intArr, value1)、Array.LastIndexOf(intArr, value1)、Array.BinarySearch(intArr, value2)在找到相应的元素时
会返回找到的元素的下标,如果没有找到的话,前两者会返回-1,最后⼀种会返回⼀个负数。
Array的Constains⽅法(⽤来查找某个元素是否存在)是对IList中的⽅法的实现,所以在使⽤时要先将其转换为IList对象,转换格式
为((System.Collections.IList)intArr).Contains(元素)
其中(System.Collections.IList)intArr是将intArr强制转化为IList类型,再外⾯的括号是为了将转化后的作为⼀个整体调⽤constains
⽅法。

输出效果



这篇关于C#数组查找元素的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!


扫一扫关注最新编程教程