C# 数组之int[]
一、数组分类
数组可以简单分为3类:
- 1维数组
- 2维数组
- 交错数组
二、数组初始化
1.一维数组
int [] A = { 1,2,3,4 } 直接赋值
或者
int [] A = new int [4]{ 1,2,3,4 } new一下,并声明大小
2.二维数组
每行个数必须相同,适合规整的数据存储;
int[,] AA={ {1,2 }, { 4,5 }, {6,7 } }; 直接赋值
int[,] AA=new int[ , ] { {1,2 }, { 4,5 }, {6,7 } };new一下
int[,] AA=new int[3,2] { {1,2 }, { 4,5 }, {6,7 } };new 并同时声明大小
注意:没有声明子项长度时,数组每个子项的大小,必须和第一个子项相同。
3.交错数组
每项的个数不一定相同,自由度较高;
int[][] AAA = { new int[]{1}, new int[]{1,2}, new int[]{3,2} };
注意:交错数组和二维数组的区别是,交错数组并不限制子项的大小一致。
三、数组常用函数
int A[]的各种函数其实是由Array类来提供的,下面是Array的属性和方法:
函数名 |
方法 |
示例 |
Clear 清空 |
Clear(Array array, int index, int length); 根据元素的类型,设置数组中某个范围的元素为零、为 false 或者为 null。 |
Array.Clear(A,0,3); |
Copy 复制 |
void Copy(Array sourceArray, Array destinationArray, int length); 从一个数组A复制某范围内地 数据到另一个数组B |
Array.Copy(A, B, 3); |
GetLength 获得长度 |
int GetLength(int dimension); 获得长度 |
A.GetLength(); |
GetValue 获得某下标的值 |
Object GetValue(Int32) 获取一维数组中指定位置的值。索引由一个 32 位整数指定。 |
Object obj = A.GetValue(1) 等价于 A[1] |
SetValue 设置某下标的值 |
void SetValue(object value, int index); 当前表示设置1维数组A[index]=value; void SetValue(object value, long index1, long index2); 当前表示设置2维数组A[index1][index2]=value; |
A.SetValue(10,1); 等价于 A[1]=10 |
IndexOf 查找 |
int IndexOf(Array array, object value); 第一个出现value数值的位置 |
略 |
int LastIndexOf(Array array, object value, int startIndex); 最好出现value数值的位置 |
略 |
|
Sort 排序 |
Sort(Array array) 将数组按照某个规则排序 |
下面详解 |
Reverse 翻转 |
void Reverse(Array array); 将数组翻转 |
略 |
Resize 重设大小 |
void Resize<T>(ref T[] array, int newSize); 重新设置数组大小 |
略 |
更多函数,请详见:class Array类
四、重点函数详解
(1)Sort排序:
void Sort(Array array); 默认排序
void Sort(Array array, int index, int length); 从index开始,截取length长度的数据排序
void Sort(Array array, IComparer comparer); 常规的int/string类型数据,自定义排序
void Sort<T>(T[] array, Comparison<T> comparison); 结构体、类等复杂的数据类型 排序,在comparison自定义排序规则
void Sort(Array keys, Array items); 两组数组一起排序,结果按照数组keys的默认排序来排。
void Sort(Array keys, Array items, IComparer comparer); 两组数组一起排序,结果按照数组keys的自定义排序来排。
(2)Resize重新设置大小:
void Resize<T>(ref T[] array, int newSize);
此方法分配指定大小的新数组,将元素从旧的数组复制到新,然后使用新替换旧的数组。array必须是一维数组。
C# 数组之int[]的更多相关文章
- C#List转字符串,字符串转List,字符数组转Int数组
List转字符串 [C#] 纯文本查看 复制代码 ? 01 02 List<string> List = new List<string>(); string strArray ...
- java 字节数组转int
4字节数组转int类型 小端模式 /** * 数组转int类型 * * @param src * @return */ public static int bytesToInt(byte[] src) ...
- 【转】java中byte数组与int类型的转换(两种方式)----不错
原文网址:http://blog.csdn.net/piaojun_pj/article/details/5903009 java中byte数组与int类型的转换,在网络编程中这个算法是最基本的算法, ...
- C# string数组转int数组(转载)
C# string数组转int数组 用法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 //字符串数组(源数组) string[] sNums = new[] {"1 ...
- C# string数组转int数组
用法 //字符串数组(源数组) string[] sNums = new[] {"1", "2"}; //整型数组(目标数组) int[] iNums; //转 ...
- byte数组和int之间相互转化的方法
Java中byte数组和int类型的转换,在网络编程中这个算法是最基本的算法,我们都知道,在socket传输中,发送者接收的数据都是byte数组,但是int类型是4个byte组成的,如何把一个整形in ...
- 数组转集合、集合转数组、字符串数组与int型、long型数组等的转换
在项目中经常会遇到数组转集合.集合转数组.数组之间类型转换等操作 1.数组转集合 为了实现把一个数组转换成一个ArrayList,很多Java程序员会使用如下的代码: String str[] = { ...
- 【转】C# string数组转int数组
//字符串数组(源数组) string[] sNums = new[] {"1", "2"}; //整型数组(目标数组) int[] iNums; //转换方法 ...
- Java 中 byte、byte 数组和 int、long 之间的转换
Java 中 byte 和 int 之间的转换源码: //byte 与 int 的相互转换 public static byte intToByte(int x) { return (byte) x; ...
- string 数组转 int 数组
用法 1 2 3 4 5 6 7 8 9 10 11 12 13 14 //字符串数组(源数组) string[] sNums = new[] {"1", "2" ...
随机推荐
- axios无法在ie9,10,11环境下运行的问题解决
npm install es6-promise --save-dev import promise from 'es6-promise'; promise.polyfill();
- 写xml时候的一个坑
<DOCTYPE scores[]>这一行总是显示错误,折腾了一晚上,后来无意错误在于:<!ELEMENT scores(student+)>应该写成:<!ELEMENT ...
- BZOJ 1680 [Usaco2005 Mar]Yogurt factory:贪心【只用考虑上一个】
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=1680 题意: 在接下来的n周内,第i周生产一吨酸奶的成本为c[i],订单为y[i]吨酸奶. ...
- 分享知识-快乐自己:SpringMvc后台Date对象数据 到 前台页面的显示转换
常常为日期格式的转换而烦恼吗?那么就试试看看楼主的方式吧!让你摆脱烦恼,从而快乐撸码. 如果你只用作于一个日期的显示采用方式如下: 导入:相应的类库 <%@ taglib uri="h ...
- Codeforces Gym 101190 NEERC 16 .D Delight for a Cat (上下界的费用流)
ls是一个特别堕落的小朋友,对于n个连续的小时,他将要么睡觉要么打隔膜,一个小时内他不能既睡觉也打隔膜 ,因此一个小时内他只能选择睡觉或者打隔膜,当然他也必须选择睡觉或打隔膜,对于每一个小时,他选择睡 ...
- Trie 树内存消耗问题
大家都知道,Trie树(又称字典树)是一种树型数据结构,用于保存大量的字符串.它的优点是:利用字符串的公共前缀来节约存储空间. 相对来说,Trie树是一种比较简单的数据结构,比较易于理解.话说上帝是公 ...
- 51nod 1443 路径和树——最短路生成树
题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1443 不只是做一遍最短路.还要在可以选的边里选最短的才行. 以为是 ...
- AI-Info-Micron-Insight:Intelligence Accelerated™
ylbtech-AI-Info-Micron-Insight:Intelligence Accelerated™ Intelligence Accelerated™ Micron Insight 大会 ...
- 网络编程 recv()函数
recv()是编程语言函数. 函数原型int recv( _In_ SOCKET s, _Out_ char *buf, _In_ int len, _In_ int flags); 这里只描述同步S ...
- java.lang.NoClassDefFoundError: javassist/util/proxy/MethodFilter
转自:https://blog.csdn.net/rchm8519/article/details/23788053 1. ERROR - Context initialization failedo ...