C#中判断一个数组中是否存在某个数组值 及相关

声明:reference:http://www.cnblogs.com/icebutterfly/archive/2010/06/22/1762738.html;http://blog.csdn.net/jimlong/article/details/3951314

paste 1:

(1) 第一种方法:

int[] ia = {1,2,3};
int id = Array.IndexOf(ia,1); // 这里的1就是你要查找的值
if(id==-1)
  // 不存在
else
  // 存在

(2) 第二种方法:

string[] strArr = {"a","b","c","d","e"};
bool exists = ((IList)strArr).Contains("a");
if(exists) 
  // 存在
else
  // 不存在

注意: 用IList需要using System.Collections;

paste 2:

数组是一种常用的数据类型,且属于引用类型。它是由一组相同数据类型的元素构成的。在C#语言的类型系统中,数组由抽象类System.Array派生而来的。在内存中,数组占用一块连续的内存,元素按顺序连续存放在一起,数组中每一个单独的元素并没有自己的名字,但是可以通过其位置(索引)来进行访问或修改。

在C#中,数组元素的索引是从0开始的,即对于有N个元素的数组,其索引范围是从0~N-1。

在这里重点讨论一下一位数组的使用方法。

1.一维数组的声明

数组声明时,主要声明数组的名称和所包含的元素类型,一般格式如下:
                         数组类型[] 数组名;

数组类型,可以使C#中任意有效的数据类型,包括类;数组名可以是C#中任意有效的标识符。下面是数组声明的几个例子:

int[ ]  num;
       float [ ]  fNum;
       string[ ]  sWords;
       Studnet[ ] stu;         //Student是已定义好的类类型

注意:

数据类型[ ] 是数组类型,变量名放在[ ]后面,这与C和C++是不同的;

声明数组时,不能指定长度。

2.一维数组的创建

创建数组就是给数组对象分配内存。因为数组本身也是类,所以跟类一样,声明数组时,并没有真正创建数组,使用前,要用new操作符来创建数组对象。创建方法有以下几种方法:

(1)先声明,后创建

形式为:

 数据类型[ ]  数组名;
                         数组名 = new 数据类型[元素个数];

下面举几个例子:

int [] num;   num = new int[10];        //声明并创建了一个具有10个整型元素的数组num。
           string[ ]  str;  str = new string[3];     //声明并创建了一个具有3个字符串数据类型的数组str.
           double [] dnum;  dnum = new double[5];  //声明并创建了一个具有5个double型数据元素的数组dnum.

(2)声明的同时创建数组

数据类型[ ]  数组名 =  new 数据类型[元素个数];

下面是几个例子:

int[] num = new int[10];
           double[] t = new double[4];
           short[] st = new short[17];

3.一维数组的初始化

数组在定义的同时给定元素的值,即为数组的初始化,初始化方法有以下几种:

(1)数据类型[ ]  数组名 = new 数据类型[元素个数]{初始值列表};  如以下例子:

int [] num = new int[4]{12,34,56,78};
               string[ ] str = new string[3]{"you","and","me"};
               float[ ] f = new float[5]{1.345f,12,13.5f,109.345f,12.1f};

(2)省略数组的大小,即:数据类型[ ]  数组名 = new 数据类型[ ]{初始值列表};  如以下的例子:

short[ ] st = new short[]{2,4,67,3};        //数组元素的个数为4
                int[ ] iNum = new int[]{23,45,67,89,100,234,567,234};     //数组元素的个数为8

(3)进一步省略new和数据类型[],即:数据类型[ ]  数组名 = {初始值列表};  如以下的例子:

string[ ] names = {"wangtao","liuli","sanmao","shanghaitan","jinghuayanyun"};
                int [ ] iNum = {45,28,34,74,84};

4.一维数组的赋值

要给数组赋值,需要用到数组的索引,格式为:

 数组名[索引值] = 数据的值;

下面试一个例子:

int [] a = new int[4];

a[0] = 24;
       a[1] = 54;
       a[2] = 87;
       a[3] = 93;

注意到以上的例子索引是从0~3。我们也看出,在给数组进行大量的赋值时,显得较麻烦,不如初始化方便。

5.数组类常用属性和方法

Length   获得数组元素的个数

Rank       获得数组的秩(维数),对于一维数组来说,Rank 总是为1。

GetLength(int)   获得指定维度的元素个数。

6.数组应用举例

(1)用选择法对10个数按着由小到大进行排序。

源程序代码如下:

using System;

class Class1
       {
              static void Sort(int[] a)
              {
                      int i,j,k,temp;
                      for(i=0;i<a.Length-1;i++)
                      {
                                 k=i;
                                 for(j=i+1;j<a.Length;j++)
                                 if(a[k]>a[j])
                                          k=j;
                                 if(k!=i)
                                 {temp = a[i];a[i] = a[k]; a[k] = temp;}
                         }
                }
                static void Main(string[] args)
                {
                             int[] AA = new int[]{918,124,58,1125,825,51,82};
                             Sort(AA);
                             Console.WriteLine("排序后的结果:");
                             for(int i=0;i<AA.Length;i++)
                                     Console.Write(AA[i]+" ");
                              Console.WriteLine();
                 }
       }

运行结果如下:

(2)找出整型数组中最大的元素和其索引值。

源程序代码如下:

运行结果如下:

时间: 2024-08-05 12:45:09

C#中判断一个数组中是否存在某个数组值 及相关的相关文章

Excel中判断一个表中的某一列的数据在另一列中是否存在

  A B C D 1 10   3 有 2 6   e 无 3 3   6 有 判断c列的值在A列中是否存在(假定C列为需要判断列,A列为目标列) 在D1中输入以下公式,然后下拉公式即可 =IF(COUNTIF(A:A,C1)>0,"有","无") =IF(COUNTIF(目标列,判断列首个单元格)>0,"是","否")

算法积累(字符串转换驼峰,判断一个字符串中那个字母出现次数最多,并且出现了几次)

因为算法比较烂,所以想做一下这方面的积累. 尽量能够每天学习一个新算法吧.(不过估计很悬) 好吧,今天第一个是字符串转换驼峰 直接上代码 var str = 'toupper-case'; var arr = str.split('-'); //toupper,case for (var i = 1; i < arr.length; i++) { //把除了第一个数组后面的数组的第一个值设置为大写然后大写字母和去掉第一个字符的剩下的字符进行拼合 arr[i] = arr[i].charAt(0)

在一组降序排列的数组中插入一个数据,插入后,数组中数据依然按降序排列

分析: 1.数组固定,是一个倒序的数组 2.插入一个数据,这个数据插在哪呢,要比较,与数组中所有的元素比较,这里需要一个循环,因为是降序的数组,所以当第一次遇到比自己小的,那么这个位置就是要插入的位置 3.因为上一步被占了位置,那么从这个插入的数据开始,后面的原本的数据都得向右移一位 /** * */ package com.cn.u4; import java.util.Scanner; /** * @author Administrator *向有序数组中插入学员成绩 * 在一组降序排列的数

判断一个字符串中是否含有中文字符:

python中的encode和decode: 首先,在Python中字符串的表示是 用unicode编码.所以在做编码转换时,通常要以unicode作为中间编码. decode的作用是将其他编码的字符串转换成unicode编码,比如 a.decode('utf-8'),表示将utf-8编码的字符串转换成unicode编码 encode的作用是将unicode编码的字符串转换成其他编码格式的字符串,比如b.encode('utf-8'),表示将unicode编码格式转换成utf-8编码格式的字符串

jquery ajax中支持哪些返回类型以及js中判断一个类型常用的方法?

1 jquery ajax中支持哪些返回类型在JQuery中,AJAX有三种实现方式:$.ajax() , $.post , $.get(). 预期服务器返回的数据类型.如果不指定,jQuery 将自动根据 HTTP 包 MIME 信息来智能判断,比如 XML MIME 类型就被识别为 XML.在 1.4 中,JSON 就会生成一个 JavaScript 对象,而 script 则会执行这个脚本.随后服务器端返回的数据会根据这个值解析后,传递给回调 函数.可用值: •"xml": 返回

C#中判断一个网址是否可以打开

public static void GetPage(String url) { try { // Creates an HttpWebRequest for the specified URL. HttpWebRequest myHttpWebRequest = (HttpWebRequest)WebRequest.Create(url); // Sends the HttpWebRequest and waits for a response. HttpWebResponse myHttpW

判断一个数字中是否包含两个相同的子串并输出

功能:判断一个数字中是否包含两个相同的子串(字串长度至少大于等于2),并输出(仅输出第一次相同的子串) 1 package ren.laughing.test.problem; 2 3 import java.util.Scanner; 4 5 /** 6 * 功能:判断一个数字中是否包含两个相同的子串(字串长度至少大于等于2),并输出(仅输出第一次相同的子串) 7 * 8 * @author Laughing_Lz 9 * @time 2016年7月4日 10 */ 11 public cla

java 判断一个字符串中的数字:是否为数字、是否包含数字、截取数字

题外话: JavaScript中判断一个字符是否为数字,用函数:isDigit(); 一.判断一个字符串是否都为数字 package com.cmc.util; import java.util.regex.Matcher; import java.util.regex.Pattern; public class DigitUtil { public static void main(String[] args) { String str="123d"; System.out.prin

Linux shell 中判断一个变量是否为空 的方法

判断一个脚本中的变量是否为空,我写了一个这样的shell脚本: #!/bin/sh #filename: test.sh para1= if [ ! -n $para1 ]; then echo "IS NULL" else echo "NOT NULL" fi 然后把该脚本:test.sh通过chmod +x 改为可以执行的脚本,执行后输出的结果为: NOT NULL,很是奇怪,最后,通过查询一些资料发现,可以通过如下方式判断一个shell变量是否为空: 1. 变

C#判断一个类中有无&quot;指定名称&quot;的方法

C#中可以通过反射分析元数据来解决这个问题,示例代码如下: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 using System; using System.Reflection; namespace Hello {     class Program     {