C#中的数组【转】
目录
为方便起见,以下数组均定义为整型
数组的声明
C#声明数组时,方括号[]必须跟在类型后面,而不是标识符后面
1. 声明一维数组
C#数组的大小不是其类型的一部分,而在C语言中却是数组类型的一部分
int[] mySigArray = new int[4]; //声明数组类型,并使用new关键字为他分配内存空间 /*上述声明可分解为以下两步*/
int[] mySigArray; //声明数组类型
mySigArray = new int[4]; //使用new关键字为他分配内存空间
另外C#声明数组时支持分配内存的方括号内是整型变量或变量表达式,只要事先确定了变量的值即可(这个在C语言的C99标准出现之前是不允许的)
int[] mySigArray = new int[n]; //n的值必须事先确定,声明之后即使改变n的值数组大小也不会变
2. 声明多维数组
int[,] myMulArray = new int[4,3]; //声明二维整型数组
3. 声明锯齿数组(数组的数组)
多维数组的大小是矩形的,例如3X3(也可以是是4×3,只需每行大小相同)个元素。而锯齿数组的大小设置比较灵活,在锯齿数组中,每一行都可以有不同的大小,如下图,锯齿数组成锯齿状

int[][] mySawArray = new int[3][]; //注意与二维数组不同,这里有两个方括号
数组的初始化
如果有初始化数据,可以用以下最简单的形式初始化
int[] mySigArray = {1,2,3,4}; //一维数组初始化
int[,] myMulArray = {{1,2,3},{4,5,6},{7,8,9}}; //二维数组初始化
int[][] mySawArray = {new int[] {1,2},new int[] {3,4,5,6,7,8},new int[] {9,10,11}}; //锯齿数组初始化
使用Array的Clear来初始化数组
byte[] tt = new byte[2147483591];
Array.Clear(tt, 0, tt.Length)
数组的访问
1. 访问上述初始化的的数组中单个元素
int i = mySigArray[2]; //i=3
int j = myMulArray[2,1]; //j=8
int k = mySawArray[2][1]; //k=10 注意二维数组与锯齿数组的区别
2. 遍历访问数组元素
C#提供了foreach语句,该语句提供了一种简单、明了的方法来循环访问数组
foreach(int m in myArray) //将所有数组元素的值加1,myArray可以是一维、多维或锯齿数组
{
m++;
}
另外也可以用for循环遍历数组,使用这种方式可以更好的控制数组元素(知道每次循环中的数组对象是哪个),下面这段代码用foreach语句是无法实现的

for (int i = 0; i< mySawArray.Length; i++)
{
for (int j = 0; j < mySawArray[i].Length; j++)
{
myMulArray[i,j]=mySawArray[i][j]; //把锯齿数组的每个元素赋值给二维数组中相应的元素
}
}

数组的常用属性和方法
在C#中,数组实际上是对象。System.Array是所有数组类型的抽象基类型,提供创建、操作、搜索和排序数组的方法,因此所有的数组都可以使用它的属性和方法
1. 常用属性
Length:获得一个32位整数,该整数表示Array的所有维数中元素的总数,即数组的元素个数,常用来限制数组下标的大小
2. 常用方法
2.1 数组的复制
在C#中,数组的复制一般分为以下三种:

int[] pins = {3,9,7,2};
int[] copy1 = new int[pins.Length];
pins.CopyTo(copy1,0); //使用数组对象的CopyTo()方法进行复制,参数0表示从copy1数组的第一个元素(下标是0)开始放置从pins数组复制过来的值
int[] copy2 = new int[pins.Length];
Array.Copy(pins,copy2,copy2.Length); //使用Array类的一个静态方法Copy(),参数copy2.Length表示从pins数组的第一个元素开始到copy2数组所能容纳的最后一个元素(copy2.Length)都复制到copy2数组
int[] copy3 = (int[])pins.Clone(); //使用数组对象的Clone()方法,它会创建一个新的数组,返回值是一个对象,所以需要强制类型转换成恰当的类型

2.2 数组的排序
排序是编程中常用的算法之一。C#中提供了两个数组排序的方法:
Array.Sort(Array)用于对数组进行从小到大排序
Array.Reverse(Array)用于对数组进行反向排序
int[] pins = {3,9,7,2};
Array.Sort(pins); //pins={2,3,7,9}
Array.Reverse(pins); //pins={9,7,3,2}
C#中的数组【转】的更多相关文章
- 前端开发:Javascript中的数组,常用方法解析
前端开发:Javascript中的数组,常用方法解析 前言 Array是Javascript构成的一个重要的部分,它可以用来存储字符串.对象.函数.Number,它是非常强大的.因此深入了解Array ...
- JavaScript jQuery 中定义数组与操作及jquery数组操作
首先给大家介绍javascript jquery中定义数组与操作的相关知识,具体内容如下所示: 1.认识数组 数组就是某类数据的集合,数据类型可以是整型.字符串.甚至是对象Javascript不支持多 ...
- java 在循环中删除数组元素
在写代码中经常会遇到需要在数组循环中删除数组元素的情况,但删除会导致数组长度变化. package com.fortunedr.thirdReport; import java.util.ArrayL ...
- Objective-C中把数组中字典中的数据转换成URL
可能上面的标题有些拗口,学过PHP的小伙伴们都知道,PHP中的数组的下标是允许我们自定义的,PHP中的数组确切的说就是键值对.而在OC我们要用字典(Dictionary)来存储,当然了Java用的是M ...
- GCC 中零长数组与变长数组
前两天看程序,发现在某个函数中有下面这段程序: int n; //define a variable n int array[n]; //define an array with length n 在 ...
- C++中的数组
数组名作为参数时,传递的是数组的首地址, 主调函数中实参数组元素个数不应该少于形参数组的元素个数 把数组名作为参数时,一般不指定数组第一维的大小 即使指定,编译时也会被忽略的.
- javascript中关于数组的一些鄙视题
一.判断一个数组中是否有相同的元素 /* * 判断数组中是否有相同的元素的代码 */ // 方案一 function isRepeat1(arrs) { if(arrs.length > 0) ...
- Oc中的数组
========================== 数组 ========================== 一.认识数组 oc中可以把NSObject对象的子类放到数组这个集合中,但是int.f ...
- Javascript中判断数组的正确姿势
在 Javascript 中,如何判断一个变量是否是数组? 最好的方式是用 ES5 提供的 Array.isArray() 方法(毕竟原生的才是最屌的): var a = [0, 1, 2]; con ...
- C#中的数组,多维数组和交错数组
想研究一些面向对象的东西,也许是代码写得还不够多.感觉还不好,看那些教程,不是嫌太水就是太难看不懂.心情很是落寞 不过再怎样也要坚持每天发一篇博客. 这篇来说一下C#中的数组,多维数组,交错数组的一些 ...
随机推荐
- git上了github又要上码云。
<h1>关联远程仓库:github为例</h1> 1.首先在用户目录下找到.ssh 2.如果.ssh文件夹里没有id_rsa和id_rsa.pub文件,或者也没有.ssh文件夹 ...
- RecyclerView悬浮标题
效果图: 1.顶部会悬浮章的部分 2.第二章上滑会推挤第一章 3.第二章下拉会带出第一章 4.并不是所有时候都有悬浮部分(为什么这条标红,因为市面上几乎所有的悬浮都是必须存在且在顶部,害 ...
- nyoj 737 石子合并 经典区间 dp
石子合并(一) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 有N堆石子排成一排,每堆石子有一定的数量.现要将N堆石子并成为一堆.合并的过程只能每次将相邻的两堆 ...
- Redis学习篇(十二)之管道技术
通过管道技术降低往返时延 当后一条命令不依赖于前一条命令的返回结果时,可以使用管道技术将多条命令一起 发送给redis服务器,服务器执行结束之后,一起返回结果,降低了通信频度.
- [CodeForces-441E]Valera and Number
题目大意: 给你一个数x,进行k次操作: 1.有p%的概率将x翻倍: 2.有1-p%的概率将x加1. 问最后二进制下x末尾0个数的期望. 思路: 动态规划. 由于k只到200,所以每次修改只与最后8位 ...
- Codeforces Round #348 (VK Cup 2016 Round 2, Div. 2 Edition) C. Little Artem and Matrix 模拟
C. Little Artem and Matrix 题目连接: http://www.codeforces.com/contest/669/problem/C Description Little ...
- Educational Codeforces Round 12 E. Beautiful Subarrays 字典树
E. Beautiful Subarrays 题目连接: http://www.codeforces.com/contest/665/problem/E Description One day, ZS ...
- Google Code Jam 2009 Qualification Round Problem A. Alien Language
https://code.google.com/codejam/contest/90101/dashboard#s=p0 Problem After years of study, scientist ...
- 基于ARM的射频识别读卡器电路设计
http://tech.yktworld.com/201010/201010032128115666.html 来源:一卡通世界 作者:江小平,李中捷,余晓峰 2010-10-3 ...
- GNU make 指南
http://docs.huihoo.com/gnu/linux/gmake.html GNU make 指南 翻译: 哈少 译者按: 本文是一篇介绍 GNU Make 的文章,读完后读者应该基本掌握 ...