数组
可以帮我我们一次声明存储多个相同类型的变量。
用来解决同一类大量数据在内存存储和运算的功能
特点:连续、同一类数据
数组定义==>赋值==>取值
定义:
int[] nums0 = new int[10];//10是数组的长度
int[] nums1 = { 1, 2, 3, 4, 5, 6, 7 };
int[] nums2 = new int[] { 1, 2, 3 };//不推荐 比较麻烦
int[] nums3=new int[]{1,2,3,4,5,6,};//不推荐
赋值:数组名[下标]=值;
取值:数组名[下标数值] //下标从0开始,最大下标要比数组长度小1。
数组的好处:
1、对于大量数据来说,保存的时候定义一个数组即可解决
2、用循环来控制数组下标,可以对数组进行批量操作
定义:指定类型、指定长度、指定名称
分类:一维数组、二维数组、多维数组
一维数组:豆角
语法:
数组类型[] 数组名 = new 数组类型 [数组长度];
注意:在内存中开辟连续的n块空间,每一块称为数组的元素,如果想要访问数组中的某一块元素,需要通过这个元素的下标或者索引去访问。(下标{0~m},有 m-1 个元素)
数组的赋值与取值
数组长度一旦固定,就不能再被改变。
保存多个值;几乎任意类型都可以声明数组; int[] nums = new int[3];int[] nums = {5,3,8};
in[]nums=new int[3]{1,2,3};int[]nums=new int[]{2,3,5};
数组的声明:以上四种
int[] nums = new int[3]{5,3,8}//个数和声明数必须一致
int[] nums = new int[5]{5,3,8}//错误
int[] nums = new int[]{5,3,8}//正确,可以省略数组个字
使用索引器访问指定编号位置的元素,访问数组元素:nums[0]、nums[1]。索引从0开始。取到的元素的类型就是数组元素的类型。还可以对数组元素进行赋值#region 数组基础学习 int[] a = new int[5]; a[0] = 1; a[1] = 2; a[2] = 3; a[3] = 4; a[4] = 5; Console.WriteLine(a[3]); //数组类型[] 数组名 = new 数组类型[数组长度]; int[] nums = new int[10];//初值是"" 空 string[] str = new string[10];//null与" "的区别 string类型默认数组的值为null null没在内存开空间," ":空 在内存开了空间 bool[] bools = new bool[10];//初值为false nums[0] = 1; nums[1] = 2; nums[2] = 3; nums[6] = 10;//下标为6的元素 赋值为10,这是数组中的第7个元素(下标从0开始 所有它的下标为6) 已知循环次数 用for循环给数组赋值 for (int i = 0; i < nums.Length; i++) { nums[i] = i; } //再通过一个循环对数组取值 for (int i = 0; i < nums.Length; i++) { Console.WriteLine(nums[i]); } //声明方式:推荐前两种方式 int[] nums0 = new int[10]; int[] nums1 = { 1, 2, 3, 4, 5, 6, 7 }; int[] nums2 = new int[] { 1, 2, 3 };//不推荐 比较麻烦 int[] nums3=new int[]{1,2,3,4,5,6,}; #endregion常见问题:求平均值,求最大值,求和,排序
Array排序 和反序(例:)#region Array int[] nums = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 }; Array.Sort(nums);//只能针对数组做一个升序的排序 Array.Reverse(nums);//对数组进行反转。跟Array.Sort配合可以实现降序 //for (int i = 0; i < nums.Length-1; i++) //{ // for (int j = 0; j < nums.Length-1-i; j++) // { // if (nums[j]>nums[j+1])//改成小于:降序 // { // int temp = nums[j]; // nums[j] = nums[j + 1]; // nums[j + 1] = temp; // } // } //} for (int i = 0; i < nums.Length; i++) { Console.WriteLine(nums[i]); } Console.ReadKey(); #endregion
冒泡排序:
将一个数组中的元素按照从大到小或者从小到大的顺序进行排序
int[] nums={9,8,7,6,5,4,3,2,1,0}趟数和次数:
每趟出来一个最大(最小)值,趟数:n-1 趟
次数:n-趟数#region 冒泡排序 int[] a = { 423, 234, 112, 343, 653, 231, 452 }; //输出数组中的元素:输出为排序前的样子 Console.WriteLine("原数组元素:"); for (int i = 0; i < a.Length; i++) { Console.WriteLine(a[i]); } //用双层for循环做大小排序并输出(例如:从小到大) Console.WriteLine("按照从小到大排序:"); for (int i = 1; i <= a.Length; i++)//外层比较多少趟 { for (int j = 1; j <= a.Length - i; j++)//内层比较多少次 { if (a[j - 1] > a[j])//如果第一个数组元素大于第二个数组元素就把 { int temp = a[j - 1]; a[j - 1] = a[j]; a[j] = temp; } } } for (int i = 0; i < a.Length; i++)//把数组中已经排好的数组输出 { Console.WriteLine(a[i]); } #endregion二分查询
前提:数组必须是有序的。
二维数组
语法:······略······
相当于一个表格
可以做简单推箱子
多维数组
······略······