C# 编程--数组
数组
可以帮我我们一次声明存储多个相同类型的变量。
用来解决同一类大量数据在内存存储和运算的功能
特点:连续、同一类数据
数组定义==>赋值==>取值
定义:
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[];
a[] = ;
a[] = ;
a[] = ;
a[] = ;
a[] = ;
Console.WriteLine(a[]); //数组类型[] 数组名 = new 数组类型[数组长度];
int[] nums = new int[];//初值是"" 空 string[] str = new string[];//null与" "的区别 string类型默认数组的值为null null没在内存开空间," ":空 在内存开了空间
bool[] bools = new bool[];//初值为false nums[] = ;
nums[] = ;
nums[] = ;
nums[] = ;//下标为6的元素 赋值为10,这是数组中的第7个元素(下标从0开始 所有它的下标为6) 已知循环次数 用for循环给数组赋值
for (int i = ; i < nums.Length; i++)
{
nums[i] = i;
}
//再通过一个循环对数组取值
for (int i = ; i < nums.Length; i++)
{
Console.WriteLine(nums[i]);
} //声明方式:推荐前两种方式
int[] nums0 = new int[];
int[] nums1 = { , , , , , , }; int[] nums2 = new int[] { , , };//不推荐 比较麻烦
int[] nums3=new int[]{,,,,,,};
#endregion常见问题:求平均值,求最大值,求和,排序
Array排序 和反序(例:)#region Array
int[] nums = { , , , , , , , , , };
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 = ; 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 = { , , , , , , };
//输出数组中的元素:输出为排序前的样子
Console.WriteLine("原数组元素:");
for (int i = ; i < a.Length; i++)
{
Console.WriteLine(a[i]);
} //用双层for循环做大小排序并输出(例如:从小到大)
Console.WriteLine("按照从小到大排序:");
for (int i = ; i <= a.Length; i++)//外层比较多少趟
{
for (int j = ; j <= a.Length - i; j++)//内层比较多少次
{
if (a[j - ] > a[j])//如果第一个数组元素大于第二个数组元素就把
{
int temp = a[j - ];
a[j - ] = a[j];
a[j] = temp;
}
}
}
for (int i = ; i < a.Length; i++)//把数组中已经排好的数组输出
{
Console.WriteLine(a[i]);
}
#endregion二分查询
前提:数组必须是有序的。
二维数组
语法:······略······
相当于一个表格
可以做简单推箱子
多维数组
······略······
C# 编程--数组的更多相关文章
- [ SHELL编程 ] 数组、关联数组和awk数组
本文主要对shell编程中常用的数组.关联数组和awk数组定义.操作以及注意事项做个总结,并提供具体案例. 数组 数组定义:一对圆括号表示数组,数组元素之间用空格符号分割. Array=(val1 v ...
- shell编程-数组
#!bin/bash/ A=(a b c hello) echo ${A[*]} echo ${A[@]} ]} ]} ]} ]} ]}echo ${#A[*]} #测数组长度方法1echo ${#A ...
- Linux Shell脚本编程-数组和字符串处理
数组 1.数组的定义及声明 变量:存储单个元素的内存空间 数组:存储多个元素的连续的内存空间,相当于多个变量的集合 数组名:整个数组只有一个名字 索引:编号从0开始,属于数值索引:bash的数组支持 ...
- Shell 编程 数组
本篇主要写一些shell脚本数组的使用. 数组定义 数组名=(value0 value1 vlaue2 ...) 数组名=([0]=value [1]=value [2]=vlaue ...) 列表名 ...
- shell脚本编程数组
数组: 变量:存储单个元素的内存空间 数组:存储多个元素的连续的内存空间,相当于多个变量的集合 数组名和索引 索引:编号从0开始,属于数值索引 注意:索引可支持使用自定义的格式,而不仅是数值格式,即为 ...
- c# 编程--数组例题
1.输入十个学生的成绩,找出最高分 #region 输入十个学生的成绩,找出最高分 //输入十个学生的成绩,找出最高分 ]; ; i < ; i++) { ; Console.Write(&qu ...
- shell数组编程
.数组定义 [chengmo@centos5 ~]$ a=( ) [chengmo@centos5 ~]$ echo $a 一对括号表示是数组,数组元素用“空格”符号分割开. .数组读取与赋值 得到长 ...
- shell编程企业级实战(2)
Vim配置文件.vimrc vim配置文件 if 条件语句 if是最常见的条件判断语句 例1:如果不存在/backup目录就创建. [root@web-01 /server/tools]# vim 0 ...
- labview学习之“创建数组”函数
“创建数组”函数 一.位置:“函数”-“编程”-“数组”-“创建数组” 其图标为: 图1 图标 二.简介: “创建数组”函数有两种模式,一种是“连接模式”,一种是“添加模式”. 如需切换两种模式,可右 ...
随机推荐
- vue,一路走来(8)--mint-ui的组件问题
Mint-ui的复选框列表Checklist和Radio 由于我在main.js里已经引用了全部的组件了,这里就不再按需引入了. 一直想着如何将自己的数据添加到 label 和 value里面,后面发 ...
- 第十五章 Kubernetes调度器
一.简介 Scheduler 是 kubernetes 的调度器,主要的任务是把定义的 pod 分配到集群的节点上.听起来非常简单,但有很多要考虑的问题: ① 公平:如何保证每个节点都能被分配资源 ② ...
- HDU-5378 概率DP
题意:给定一棵有n个节点的树,现在要给节点附1~n的权值(各节点权值不能相同),一棵子树的领袖就是子树中权值最大的节点,问有多少种分配方案使得最后有恰好K个领袖. 解法:这道题一看以为是树上的计数问题 ...
- python如何获取变量的变量名
假设现在存在一个值为1变量名为a的变量,如何通过一个函数获取该变量的变量名a? 上面这个需求来源于某群友的一个要求,希望能有一个这样的函数来方便打印. 这个需求很扯淡啊,为什么不用格式化输出?它回复到 ...
- Spring---数据缓存Cache
1.Spring缓存支持 1.1.Spring定义了org.springframework.cache.CacheManager类.org.springframework.cache.Cache类接口 ...
- 关于iphone设置显示模式为标准模式和放大模式时的区别
参考来自:https://www.jianshu.com/p/5f61d914114b CGFloat scale = [[UIScreen mainScreen] scale]; CGFloat n ...
- 2019牛客多校第六场 B - Shorten IPv6 Address 模拟
B - Shorten IPv6 Address 题意 给你\(128\)位的二进制,转换为十六进制. 每\(4\)位十六进制分为\(1\)组,每两组用一个\(":"\)分开. 每 ...
- 【BZOJ2555】SubString(后缀自动机,LCT)
题意:给你一个字符串init,要求你支持两个操作 (1):在当前字符串的后面插入一个字符串 (2):询问字符串s在当前字符串中出现了几次?(作为连续子串) 你必须在线支持这些操作. 长度 <= ...
- vue打包配置发布路径
目的:配置路径,让打包后的dist在本地可以打开. 方法:修改build文件夹下边的的webpack.dev.conf.js文件,找到devServer下边的publicPath,这个来源于confi ...
- RHEL 使用epel源
转自http://www.linuxidc.com/Linux/2012-10/71850.htm 设置epel源.方法如下: 32位系统选择:rpm -ivh http://download.Fed ...