自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

C#數(shù)組操作詳細(xì)剖析

開發(fā) 后端
這里介紹C#數(shù)組操作,數(shù)組是相同類型的對(duì)象的集合。由于數(shù)組幾乎可以為任意長(zhǎng)度,因此可以使用數(shù)組存儲(chǔ)數(shù)千乃至數(shù)百萬個(gè)對(duì)象,但必須在創(chuàng)建數(shù)組時(shí)就確定其大小。

本文向大家介紹C#數(shù)組操作,可能好多人還不了解C#數(shù)組操作,沒有關(guān)系,看完本文你肯定有不少收獲,希望本文能教會(huì)你更多東西。

數(shù)組是相同類型的對(duì)象的集合。由于數(shù)組幾乎可以為任意長(zhǎng)度,因此可以使用數(shù)組存儲(chǔ)數(shù)千乃至數(shù)百萬個(gè)對(duì)象,但必須在創(chuàng)建數(shù)組時(shí)就確定其大小。數(shù)組中的每項(xiàng)都按索引進(jìn)行訪問,索引是一個(gè)數(shù)字,指示對(duì)象在數(shù)組中的存儲(chǔ)位置或槽。數(shù)組既可用于存儲(chǔ) 引用類型,也可用于存儲(chǔ) 值類型。

C#數(shù)組操作程序:

  1. using System;  
  2. using System.Collections.Generic;  
  3. using System.Text;  
  4.  
  5. namespace ClassAboutArray  
  6. {  
  7. public class CreateArray  
  8. {  
  9. /// <summary> 
  10. /// 一維數(shù)組的定義  
  11. /// </summary> 
  12. public void testArr1()  
  13. {  
  14. int[] myIntArr = new int[100];  
  15. //定義一個(gè)長(zhǎng)度為100的int數(shù)組  
  16. string[] mystringArr = new string[100];  
  17. //定義一個(gè)長(zhǎng)度為100的string數(shù)組  
  18. object[] myObjectArr = new object[100];  
  19. //定義一個(gè)長(zhǎng)度為100的int數(shù)組  
  20.  
  21. int[] myIntArr2 = new int[] { 1, 2, 3 };   
  22. //定義一個(gè)int數(shù)組,長(zhǎng)度為3  
  23. string[] mystringArr2 = new string[] { "油", "鹽" };  
  24. //定義一個(gè)string數(shù)組,長(zhǎng)度為2  
  25. }  
  26.  
  27. /// <summary> 
  28. /// 多維數(shù)組的定義  
  29. /// </summary> 
  30. public void testArr2()  
  31. {  
  32. int[,] myIntArr = new int[10, 100];   
  33. //定義一個(gè)10*100的二維int數(shù)組  
  34. string[, ,] mystringArr = new string[2, 2, 3];   
  35. //定義一個(gè)2*2*3的三維string數(shù)組   
  36.  
  37. int[,] myIntArr2 = new int[,] { { 1, 2, 3 }, { -1, -2, -3 } };  
  38. //定義一個(gè)2*3的二維int數(shù)組,并初始化  
  39. string[,] mystringArr2 = new string[,] { { "油", "鹽" }, { "《圍城》", "《晨露》" } };  
  40. //定義一個(gè)2*2的二維string數(shù)組,并初始化  
  41. }  
  42.  
  43. /// <summary> 
  44. /// 交錯(cuò)數(shù)組的定義  
  45. /// </summary> 
  46. public void testArr3()  
  47. {  
  48. int[][] myJaggedArray = new int[3][];  
  49. myJaggedArray[0] = new int[5];  
  50. myJaggedArray[1] = new int[4];  
  51. myJaggedArray[2] = new int[2];  
  52.  
  53. int[][] myJaggedArray2 = new int[][]  
  54.  {  
  55. new int[] {1,3,5,7,9},  
  56. new int[] {0,2,4,6},  
  57. new int[] {11,22}  
  58.  };  
  59. }  
  60. }  
  61.  
  62. public class TraverseArray  
  63. {  
  64. /// <summary> 
  65. /// 使用GetLowerBound|GetUpperBound遍歷數(shù)組  
  66. /// </summary> 
  67. public void test1()  
  68. {  
  69. //定義二維數(shù)組  
  70. string[,] myStrArr2 = new string[,] 
    { { "油", "鹽" }, { "《圍城》", "《晨露》" }, { "毛毛熊", "Snoopy" } };  
  71. //循環(huán)輸出  
  72. for (int i = myStrArr2.GetLowerBound(0); i <= myStrArr2.GetUpperBound(0); i++)  
  73. {  
  74. Console.WriteLine("item{0}", i);  
  75. for (int j = myStrArr2.GetLowerBound(1); j <= myStrArr2.GetUpperBound(1); j++)  
  76. {  
  77. Console.WriteLine(" item{0}{1}:{2}", i, j, myStrArr2.GetValue(i, j));  
  78. }  
  79. }  
  80. }  
  81.  
  82. /// <summary> 
  83. /// 使用foreach遍歷數(shù)組  
  84. /// </summary> 
  85. public void test2()  
  86. {  
  87. //定義二維數(shù)組  
  88. string[,] myStrArr2 = new string[,] 
    { { "油", "鹽" }, { "《圍城》", "《晨露》" }, { "毛毛熊", "Snoopy" } };  
  89. //循環(huán)輸出  
  90. foreach (string item in myStrArr2)  
  91. {  
  92. {  
  93. Console.WriteLine("{0}", item);  
  94. }  
  95. }  
  96. }  
  97. }  
  98.  
  99. public class SortArray  
  100. {  
  101. /// <summary> 
  102. /// 利用Sort方法進(jìn)行數(shù)組排序  
  103. /// </summary> 
  104. public void test1()  
  105. {  
  106. //定義數(shù)組  
  107. int[] myArr = { 5, 4, 3, 2, 1 };  
  108.  
  109. //輸出原始數(shù)組:原始數(shù)組:5->4->3->2->1-> 
  110. Console.WriteLine("原始數(shù)組:");  
  111. for (int i = 0; i < myArr.Length; i++)  
  112. Console.Write("{0}->", myArr[i]);  
  113. Console.WriteLine();  
  114.  
  115. //對(duì)數(shù)組排序  
  116. Array.Sort(myArr);  
  117.  
  118. //并輸出排序后的數(shù)組:1->2->3->4->5-> 
  119. Console.WriteLine("排序以后數(shù)組:");  
  120. for (int i = 0; i < myArr.Length; i++)  
  121. Console.Write("{0}->", myArr[i]);  
  122. }  
  123.  
  124. /// <summary> 
  125. /// 多個(gè)數(shù)組的關(guān)鍵字排序  
  126. /// </summary> 
  127. public void test2()  
  128. {  
  129. //定義數(shù)組  
  130. int[] arrSid = { 5, 4, 3, 2, 1 };  
  131. string[] arrSname = { "張三", "李四", "王五", "麻子", "淘氣" };  
  132.  
  133. //輸出原始數(shù)組:原始數(shù)組:張三(5)->李四(4)->王五(3)->麻子(2)->淘氣(1)-> 
  134. Console.WriteLine("原始數(shù)組:");  
  135. for (int i = 0; i < arrSid.Length; i++)  
  136. Console.Write("{0}({1})->", arrSname[i], arrSid[i]);  
  137. Console.WriteLine();  
  138.  
  139. //根據(jù)學(xué)號(hào)關(guān)鍵字排序  
  140. Array.Sort(arrSid, arrSname);  
  141.  
  142. //并輸出排序后的數(shù)組:淘氣(1)->麻子(2)->王五(3)->李四(4)->張三(5)  
  143. Console.WriteLine("排序以后數(shù)組:");  
  144. for (int i = 0; i < arrSid.Length; i++)  
  145. Console.Write("{0}({1})->", arrSname[i], arrSid[i]);  
  146. }  
  147. }  
  148.  
  149. public class SearchArray  
  150. {  
  151. /// <summary> 
  152. /// 利用BinarySearch方法搜索元素  
  153. /// </summary> 
  154. public void test1()  
  155. {  
  156. //定義數(shù)組  
  157. int[] myArr = { 5, 4, 3, 2, 1 };  
  158.  
  159. //對(duì)數(shù)組排序  
  160. Array.Sort(myArr);  
  161.  
  162. //搜索  
  163. int target = 3;  
  164. int result = Array.BinarySearch(myArr, target); //2  
  165. Console.WriteLine("{0}的下標(biāo)為{1}", target, result); //2  
  166. }  
  167.  
  168. /// <summary> 
  169. /// 判斷是否包含某個(gè)值  
  170. /// </summary> 
  171. public void test2()  
  172. {  
  173. //定義數(shù)組  
  174. string[] arrSname = { "張三", "李四", "王五", "麻子", "淘氣" };  
  175.  
  176. //判斷是否含有某值  
  177. string target = "王五";  
  178. bool result = ((System.Collections.IList)arrSname).Contains(target);  
  179. Console.WriteLine("包含{0}?{1}", target, result); //true  
  180. }  
  181. }  
  182.  
  183. public class ReverseArray  
  184. {  
  185. /// <summary> 
  186. /// 利用Reverse方法反轉(zhuǎn)數(shù)組  
  187. /// </summary> 
  188. public void test1()  
  189. {  
  190. //定義數(shù)組  
  191. int[] myArr = { 5, 4, 3, 2, 1 };  
  192.  
  193. //輸出原始數(shù)組:原始數(shù)組:5->4->3->2->1-> 
  194. Console.WriteLine("原始數(shù)組:");  
  195. for (int i = 0; i < myArr.Length; i++)  
  196. Console.Write("{0}->", myArr[i]);  
  197. Console.WriteLine();  
  198.  
  199. //對(duì)數(shù)組反轉(zhuǎn)  
  200. Array.Reverse(myArr);  
  201.  
  202. //并輸出反轉(zhuǎn)后的數(shù)組:1->2->3->4->5-> 
  203. Console.WriteLine("反轉(zhuǎn)以后數(shù)組:");  
  204. for (int i = 0; i < myArr.Length; i++)  
  205. Console.Write("{0}->", myArr[i]);  
  206. }  
  207. }  
  208.  
  209. public class CopyArray  
  210. {  
  211. /// <summary> 
  212. /// 利用Copy靜態(tài)方法復(fù)制數(shù)組  
  213. /// </summary> 
  214. public void test1()  
  215. {  
  216. //定義數(shù)組  
  217. int[] myArr = { 5, 4, 3, 2, 1 };  
  218.  
  219. //輸出原始數(shù)組:原始數(shù)組:5->4->3->2->1-> 
  220. Console.WriteLine("原始數(shù)組:");  
  221. for (int i = 0; i < myArr.Length; i++)  
  222. Console.Write("{0}->", myArr[i]);  
  223. Console.WriteLine();  
  224.  
  225. //復(fù)制數(shù)組  
  226. int[] newnewArr = new int[3];  
  227. Array.Copy(myArr, newArr, 3);  
  228.  
  229. //并輸出反復(fù)制的數(shù)組:5->4->3-> 
  230. Console.WriteLine("復(fù)制數(shù)組:");  
  231. for (int i = 0; i < newArr.Length; i++)  
  232. Console.Write("{0}->", newArr[i]);  
  233. }  
  234.  
  235. /// <summary> 
  236. /// 利用CopyTo實(shí)例方法復(fù)制數(shù)組  
  237. /// </summary> 
  238. public void test2()  
  239. {  
  240. //定義數(shù)組  
  241. int[] myArr = { 5, 4, 3, 2, 1 };  
  242.  
  243. //輸出原始數(shù)組:原始數(shù)組:5->4->3->2->1-> 
  244. Console.WriteLine("原始數(shù)組:");  
  245. for (int i = 0; i < myArr.Length; i++)  
  246. Console.Write("{0}->", myArr[i]);  
  247. Console.WriteLine();  
  248.  
  249. //復(fù)制數(shù)組  
  250. int[] newnewArr = new int[7];  
  251. myArr.CopyTo(newArr, 2);  
  252.  
  253. //并輸出反復(fù)制的數(shù)組:0->0->5->4->3->2->1-> 
  254. Console.WriteLine("復(fù)制數(shù)組:");  
  255. for (int i = 0; i < newArr.Length; i++)  
  256. Console.Write("{0}->", newArr[i]);  
  257. }  
  258. }  
  259.  
  260. public class DynamicCreateArray  
  261. {  
  262. /// <summary> 
  263. /// 利用CreateInstance動(dòng)態(tài)創(chuàng)建數(shù)組  
  264. /// </summary> 
  265. public void test1()  
  266. {  
  267. //定義長(zhǎng)度數(shù)組  
  268. int[] lengthsArr = new int[] { 3, 4 };  
  269. int[] lowerBoundsArr = { 1, 11 };  
  270.  
  271. Array arr = Array.CreateInstance(Type.GetType("System.Int32"), lengthsArr, lowerBoundsArr);  
  272.  
  273. Random r = new Random(); //聲明一個(gè)隨機(jī)數(shù)對(duì)象  
  274. //循環(huán)賦值、輸出  
  275. for (int i = arr.GetLowerBound(0) - 1; i < arr.GetUpperBound(0) - 1; i++)  
  276. {  
  277. for (int j = arr.GetLowerBound(1) - 1; j < arr.GetUpperBound(1) - 1; j++)  
  278. {  
  279. arr.SetValue((int)r.Next() % 100, i, j);//用1~100的隨即數(shù)賦值  
  280. Console.WriteLine("arr[{0},{1}]={3}", i, j, arr.GetValue(i, j));  
  281. }  
  282. }  
  283. }  
  284. }  

【編輯推薦】

  1. C#參差數(shù)組初始化概述
  2. C#數(shù)組初始化全面分析
  3. C#一維數(shù)組和多維數(shù)組淺談
  4. C#參差數(shù)組初始化概述
  5. C#動(dòng)態(tài)數(shù)組實(shí)例介紹
責(zé)任編輯:佚名 來源: 新浪科技
相關(guān)推薦

2009-08-27 17:14:36

C# Socket

2009-09-11 11:17:04

C#引用類型

2009-08-31 17:26:32

C#異常處理

2009-09-03 16:58:49

C#內(nèi)存管理

2009-08-27 17:51:34

C#匿名方法

2009-08-28 10:44:46

C#字符數(shù)組轉(zhuǎn)換

2009-09-04 11:06:40

C#訪問修飾符

2009-08-31 16:29:21

C#控制輸入法

2009-09-07 13:42:56

C# Pop3類

2009-08-28 15:38:49

C#實(shí)現(xiàn)斷點(diǎn)續(xù)傳

2009-08-31 15:39:11

C#編寫操作TreeV

2009-09-02 18:41:18

C#定義動(dòng)態(tài)控件數(shù)組

2009-09-02 16:41:56

C#聲明數(shù)組

2009-09-27 11:14:09

C#數(shù)組

2009-09-18 10:45:31

C#數(shù)組操作

2009-09-02 17:07:06

C#數(shù)組操作

2009-09-18 10:58:31

C#數(shù)組操作

2009-09-02 16:20:22

C#動(dòng)態(tài)創(chuàng)建數(shù)組

2009-09-07 14:29:52

C# ServiceC

2009-09-01 16:29:03

QuickSort C
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)