//一次性存储或者声明多个相同类型的变量 数组
//数组类型[] 数组名=new 数组类型[数组长度];
int[] nums = new int[10];
nums[0] = 1;
nums[1] = 2;
nums[2] = 3;
nums[3] = 4;
nums[4] = 5;
nums[5] = 6;
nums[6] = 7;
nums[7] = 10;
nums[8] = 9;
nums[9] = 100;
nums[10] = 200;
//表示通过一个循环给数组赋值
//表示将0-9这10个数字,依次的赋值给数组中的每一个元素
//for (int i = 0; i < nums.Length; i++)
//{
// nums[i] = i;
//}
表示通过一个循环给数组取值
//for (int i = 0; i < nums.Length; i++)
//{
// Console.WriteLine(nums[i]);
//}
Console.ReadKey();
数组中几种声明方式
//int[] nums = new int[10];这种声明数组的方式只是确定了数组的类型和长度,并没有赋值
//int[] nums = { 1, 2, 3, 4, 5 };这种声明数组的方式在声明的时候 就给数组赋值了
// int[] nums = new int[4] { 1, 2, 3, 4 };
int[] nums = new int[] { 1, 2, 3, 4 };
数组的遍历
int[] nums = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
int sum = 0;
for (int i = 0; i < nums.Length; i++)
{
// nums[i] 两种理解方式:1代表数组中当前循环到的这个元素 2、由于在循环中,也可以认为是数组
//中的每一个元素
sum += nums[i];
}
Console.WriteLine(sum);
Console.ReadKey();
数组的练习
//练习1:从一个整数数组中取出最大的整数,最小整数,总和,平均值
//int[] nums = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
//int max = nums[0];//int.MinValue;//nums[0];
//int min = nums[0];//int.MaxValue;//nums[0];
//int sum = 0;
//for (int i = 0; i < nums.Length; i++)
//{
// if (nums[i] > max)
// {
// max = nums[i];
// }
// if (nums[i] < min)
// {
// min = nums[i];
// }
// sum += nums[i];
//}
//Console.WriteLine("这个数组中的最大值是{0},最小值是{1},总和是{2},平均值是{3}", max, min, sum, sum / nums.Length);
//Console.ReadKey();
//练习3:数组里面都是人的名字,分割成:例如:老杨|老苏|老邹…”
//(老杨,老苏,老邹,老虎,老牛,老蒋,老王,老马)
//string[] names = { "老杨", "武藤兰", "老苏", "苍井空", "老赵", "孙中山" };
老杨|武藤兰|老苏|苍井空|老赵|孙中山
//string str = null;
//for (int i = 0; i < names.Length-1; i++)
//{
// str += names[i] + "|";
//}
//Console.WriteLine(str+names[names.Length-1]);
//Console.ReadKey();
//练习4:将一个整数数组的每一个元素进行如下的处理:
//如果元素是正数则将这个位置的元素的值加1,
//如果元素是负数则将这个位置的元素的值减1,如果元素是0,则不变。
//int[] nums = { -9, -87, 0, 123, 34 };
//for (int i = 0; i < nums.Length; i++)
//{
// if (nums[i] > 0)
// {
// nums[i] += 1;
// }
// else if (nums[i] < 0)
// {
// nums[i] -= 1;
// }
// else
// {
// }
//}
//for (int i = 0; i < nums.Length; i++)
//{
// Console.WriteLine(nums[i]);
//}
//Console.ReadKey();
string[] names = { "abc", "Hello", "张三", "哇哈哈哈哈", "金X恩" };
for (int i = 0; i < names.Length/2; i++)
{
string temp = names[i];
names[i] = names[names.Length - 1 - i];
names[names.Length - 1 - i] = temp;
}
for (int i = 0; i < names.Length; i++)
{
Console.WriteLine(names[i]);
}
Console.ReadKey();
冒泡法
//升序排列 降序排列
//int[] nums = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
//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]);
//}
面试可能出现的问题
升序
int[] nums = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };
Array.Sort(nums);//Sort这个方法只能对数组进行升序排列
for (int i = 0; i < nums.Length; i++)
{
Console.WriteLine(nums[i]);
}
Console.ReadKey();
降序 先升序在反转
int[] nums = { 4, 8, 6, 5, 1, 2, 9, 7, 3, 0 };
Array.Sort(nums);//Sort这个方法只能对数组进行升序排列
Array.Reverse(nums);//反转数组
for (int i = 0; i < nums.Length; i++)
{
Console.WriteLine(nums[i]);
}
Console.ReadKey();