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#中的数组,多维数组,交错数组的一些 ...
随机推荐
- Python并发编程-进程池及异步方式
进程池的基本概念 为什么有进程池的概念 效率问题 每次开启进程,都需要开启属于这个进程的内存空间 寄存器,堆栈 进程过多,操作系统的调度 进程池 python中的 先创建一个属于进程的池子 这个池子指 ...
- springMVC返回modelmap跟new hashMap的区别
今天遇到了个坑. 在springboot中 平时写接口,newHashMap,@ResponseBody 返回json对象,没什么问题 @RequestMapping("url") ...
- javascript的优缺点和内置对象
1)优点:简单易用,与Java有类似的语法,可以使用任何文本编辑工具编写,只需要浏览器就可执行程序,并且事先不用编译,逐行执行,无需进行严格的变量声明,而且内置大量现成对象,编写少量程序可以完成目标: ...
- 【BZOJ 3235】 3235: [Ahoi2013]好方的蛇 (单调栈+容斥原理)
3235: [Ahoi2013]好方的蛇 Time Limit: 10 Sec Memory Limit: 64 MBSubmit: 187 Solved: 95 Description 有一天, ...
- 【BZOJ 3133】 3133: [Baltic2013]ballmachine (线段树+倍增)
3133: [Baltic2013]ballmachine Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 148 Solved: 66 Descri ...
- NOIP2017 D2T1奶酪
这题终于是正经第一题感觉了. 只需要对相交或相切的球建一条边,然后对所有与底面有交点的球连边,再对所有与顶面有交点的球连边,bfs判断上下连通性即可. #include<iostream> ...
- hihocoder #1076 与链 dp
直接背包不可做 我们只需要知道每个数位上有多少个$1$,那么我们就能构造出解 因此,我们对每一位讨论, 可以拆出$n + \frac{n}{2} + \frac{n}{4} + ... = 2n$个物 ...
- 【MPI】矩阵向量乘法
输入作乘法的次数K 然后输入矩阵和向量的维度n 然后输入一个n维向量 然后输入K个n阶方阵 程序会给出该向量连续与此K个方阵做乘法后的结果 主要用了MPI_Gather, MPI_Allgather, ...
- [HDU1290]献给杭电五十周年校庆的礼物
[HDU1290]献给杭电五十周年校庆的礼物 题目大意: 问\(n(n\le1000)\)个平面能够将一个三维空间分成几部分. 思路: 公式\(\frac{n^3+5n+6}6\). 源代码: #in ...
- [转]Eclipse 项目转移到Android Studio遇到的问题
1.Android Studio直接导入项目是copy原项目的,无法纳入代码管控 解决方案: 英文地址:http://developer.android.com/sdk/installing/migr ...