循环的几种应用场景,数组与集合

今天自己准备记录生机勃勃篇关于遍历的博客,因为认为它是我们随后专业最常用的生龙活虎种方法了。举个例子说在叁个模块里插入小Logo,如京东网页左边的小Logo<i></i>。

循环的二种选择场景:
1.循环体鲜明,循环次数也是规定的
2.循环体分明,循环次数不鲜明,不过循环继续的标准是明确的
达成步骤:
1). 先把循环的作风搭出来.因为大家显著是循环.
2). 再把循环体写出来.
3). 在循环条件中写上循环继续的条件.
以此时候,你会发觉循环条件要用到的变量注明在循环体中
那么将这一个变量评释在外边就能够.
3.遍历钦命范围的数
福寿双全步骤.:
遍历 n – m 之间的每1个整数.
1). 先注脚1个循环增i 暗许值是n
2). 循环条件写 i <= m
3). 在循环体中 循环增量i的值正是n-m之间的每1个整数.
4). 应当要记得在循环体后面自增循环增量.
int i = n;
while(i <= m)
{
i的值就是n – m 之间的整数,打印出来就能够
i++;
}
4.搜索内定范围中切合特定条件的数
得以完结思路:
要找到n-m这些节制以内的适合特定条件的数
1). 先遍历n-m之间的每1个数.
2). 决断遍历出来的数是否符合特定条件的.借使切合就拿出去.不然就滚蛋.
int i = n;
while(i <= m)
{
if(i符合特定条件)
{
就把i拿出来.
}
i++;
}
5.求累积和与平均值
贯彻步骤:
求 n – m 之间的每一个大背头的增进和.
1). 先筹算1个框遍量,用来保存累积和.(评释在循环外)
2). 再遍历n-m之间的每一个整数.
3). 将遍历出来的每1个数 累计到 框变量之中
4). 当遍历完结今后,框变量中的数据正是n-m之间的每贰个大背头的拉长和.
6.求1堆数的最大值只怕最小值
福寿康宁步骤:
1). 摆擂台. 注解1个擂台变量. (int max =INT32_MIN; int min
=INT32_MAX;)
2). 得到那1堆数中的每1个数,将那堆数中的每1个数遍历出来
3). 将遍历出来的数和擂台上的数进行相比较,比得过就上 比但是就滚蛋.
4). 当遍历实现之后,最终擂台上的数正是他俩中的最大数.
7.计数
1). 记录循环了不怎么次.
2). 记录了有些条件满意了略微次.
贯彻步骤:
证明1个整型的变量,用来记录循环的次数
每循环1次自增.
8.穷举(1个1个的挨个试)
例如:
发生1个1-100的轻便数.
写1段代码.判别那几个数是多少.
(要求用到continue或然break关键字,叁个五个论断找到就终止)

对于初学者,想要入门web前端,要有足够的信心和持锲而不舍,不然只会越走越远,小编今后就深深的回味到。

机智图中遍历也是少不了的要害用法。

循环利用注意:
1.循环次数不分明的循环.可是规定循环继续恐怕终止的条件.
while(1) break
for(;;) break
2.采用提议:
当循环次数鲜明的时候,大家日常情状下使用for循环.
当循环次数不分明的时候.大家一般景色下选取while循环.

本人本是三个很谢绝代码的人,早前想过UI设计,可是在这里段学习时间里,发现实际上只要认真,代码实际不是很难

遍历又是循环中最广大的主题素材。

——————————————————————————————————————————
四个举足轻重字break和continue

进而作者收拾了风度翩翩套中期学C#的知识点,对于早先时期学习JavaScript有一点都不小的帮手。

所谓遍历,是指有某些范围的样品数,供给把样品中的每种数据收取来风度翩翩一深入分析。

  1. break
    1).
    能够应用在switch-case的case代码块中.代表马上结束switch-case结构.
    2). break还可以够用在循环体中.
    假使在循环体中蒙受了break.就能够登时甘休近来这些轮回结构.
    在循环体的内部能够一贯截止近年来循环.
    当蒙受了break 是那个时候、马上、立时、现在、now甘休这几天轮回结构.
    不畏break后边还应该有循环体代码不会实行.
    3). 甘休循环的章程(两种)
    a. 推断循环条件得到假而结束.
    b. 在循环体的内部使用break甘休.
  2. continue
    1). continue只可以使用在循环体中.
    2). 在循环体中.假若碰到了continue.
    会立即终止本次巡回 然后回到判定循环条件.

生龙活虎、数组与聚焦
数组:能寄存放肆几个同品种的数额

比如,输出100-200里头的有着数字,它的样板范围就是100-200,必要你各样把样板中的每一个数据抽出来输出。

数码项:类型相同

再例如,将50-70里面包车型地铁富有数字相加求和,它的样本范围正是50-70,必要您各类把样板中的每一个数据抽出来累积。

①每三个数据型都有二个编号(索引或下标卡塔 尔(阿拉伯语:قطر‎

那,就是遍历难题。

②数据的目录(下标卡塔尔国是二个int类型的数字

相见遍历难点,绝大多数意况下,都亟需运用贰个循环变量,它从样板的起初值(或结束值卡塔 尔(英语:State of Qatar)最初,每趟依次增加(或依次减少卡塔尔国,那样,就足以取到每一个样书的数据。

③从0开头,依次为数量中每二个数组项编号

遍历难点的通用循环格式如下:

数组的宣示与赋值

//格局豆蔻梢头:顺序遍历
for (int i =
样本开首值; i <= 样板截止值; i++)
{
//
每便跻身循环体,i,正是收取的里边二个样书数量
}

扬言:数据类型[
] 变量名;

//情势二:逆序遍历
for (int i =
样本截至值; i >= 样品初步值; i–)
{
//
每二回跻身循环体,i,正是抽出的里边三个样板数量
}

赋值:变量名 = new
数据类型[长度](长度为int类型)

 

数据型的读取与改良:读取:变量名[索引]
                                  修改
:变量名[索引] =
值;

遍历在不相同的场馆有不的用途。一时候也许只须求领取在那之中的样书。里面或然会安置if、while等内部循环或然推断语句。

读取数组的尺寸 变量名.Length 重回类型为int

对数据的筛选、求和、计数(样板计数难点再三会和样品筛选难点联合使用。卡塔尔国方面选取很广,对今后大家工作中境遇的相干主题材料也是很有支持的。

统大器晚成书写:数据类型[ ] 变量名 = new 数据类型[长度];
(数组的表明与赋值, 数据型的读取与修正, 读取数组的尺寸)

在例子中,求质数是叁个相当好的案例。

数组项的私下认可值:三个数组成立后,它每二个数组项的值为数组项项目标暗中认可值。

对此求质数而言,用遍历计数的方式比其它艺术更易于驾驭和操作(最少作者是这么认为的卡塔尔国。这里就不现实呈报了,要是感兴趣,你能够百度时而,这里比自身这里的分解特别详细。

管见所及私下认可值:数字类型
暗许值为0
                     bool类型
暗许值为false
                     char类型
暗中认可值为
                     string类型
私下认可值为mull(表示尚无别的数据卡塔 尔(英语:State of Qatar)

示例

创制叁个长度为3的字符串数组,然后逐风姿洒脱为它的每风流倜傥项赋值为a、b、c、,最终,输出该数组的长度

统后生可畏书写

string[ ] strs = new
string[3];
strs[0] = “a”;
strs[1] = “b”;
strs[2] = “c”; sring[ ] strs
= {“a”,”b”,”c”};
Console.Write(strs.Length);
Console.Write(strs.Length);

int[ ] numbers = new
int[5];
numbers[0] = 3;
numbers[1] = -2;
numbers[2] = numbers[0] * 2

  • numbers[1];
    Console.WriteLine(numbers[3]);
    Console.WriteLine(numbers.Length);
    调控台输出4,5

二、数组的定长性

二个数组创设后,它的长度固定不改变

int[ ]nums = new
int[5];
nums = new int [6];    
     不再行使上三个数组,重新创设叁个尺寸为5的数组

数组适用于数据数量牢固的现象

相符利用数组的情景:保存100以内的兼具质数
封存太阳系中保有已知行星的身分
保存规范扑克中的全部牌面数据
保存一个星期的具有日期
别的定长的数码场景

不契合选择数组的场景:保存多个班学子音讯
保留一年中的全体日期
保存不以为意地主游戏中某游戏者的手牌数据
封存游戏某游戏用户的配备消息
此外不定长的数量场景

三、数组的遍历

再度行为:输出三个数组项

代码书写格式:Console.WriteLine(arrays
[?]);其中?为索引

int i = ?;
变量i的改变范围:0~arrays,Length-1
也足以写成:i < arrays.Length

遍历

概念:是指从数组的首先项初阶,依次取完整数组全体项

①贯彻数组的遍历,可以选用循环

②循环变量从0初步,依次取到数组的最大下标(数组的尺寸-1卡塔尔

③在循环体中,使用循环体变量作为下标,就能够抽出数组每黄金时代项的值

for (int i = 0; i <
arrays.Length; i++)
{

Console.WriteLine(arrays[i]);
}

完全兑今世码

Console.Write("亲输入数组的长度:");
int len = int,Parse(Conesole,ReadLine());
//根据用户的输入创建数组,并遍历数组为其每一项赋值
int[ ] nums = 0; i < nums.Length; i++
{
Console,Write("请输入数组第"+ (i + 1) + "项的值:");
nums[i] = int.Parse(Console.ReadLine());
}
//遍历数组nums,依次输出数组中的值
Console.Write("数组的所有项是:");
for (int i = 0; i < nums.Length; i++)
{
Console.Write(nums[i]);
if (i < nums.Length - 1)//不是最后一项
Console.Write(",");//输出一个逗号分隔

 

四、调换排序

基于输入的数进行逐项排序:简化排序:怎么样把最小的数字,放置到数组索引未0的职位

得以达成方式:把第叁个职位的数字拿出去依次和前面地点的数字实行比较,即便比前边地点数字大,则调换个地点置

任何代码完毕

for (int i = 0; i < numbers.Count - 1; i++)
{
for (int j = i + 1; j < numbers.Count; j++)
{ 
if(numbers [i]>numbers [j])
{
int temp = numbers[i];
numbers[i] = numbers [j];
numbers[j] = temp;
}
}
}

 

  

五、数组剖析器

代码示例:

Console.Write("请输入数组的长度:");
int n = int.Parse(Console.ReadLine());
int[] nums = new int[n];
{

for (int i = 0; i < nums.Length; i++)
{
Console.Write("请输入数组的第" + (i + 1) + "项:");
nums[i] = int.Parse(Console.ReadLine());
}
Console.Clear();
}
for (int i = 0; i < nums.Length - 1; i++)
{
for (int j = i + 1; j < nums.Length; j++)
if (nums[i] > nums[j])
{
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
}
Console.Write("你输入的数字从小到大的排序是:");
for (int i = 0; i < nums.Length; i++)
{
Console.Write(nums[i] + " ");
}
Console.ReadLine();
{
Console.Write("你输入的数字其中是奇数的是:");
for (int i = 0; i < nums.Length; i++)
if (nums[i] % 2 != 0)
{

{
Console.Write(nums[i] + " ");
}
}
Console.ReadLine();
}
Console.Write("你输入的数其中是质数的是:");
for (int i = 0; i < nums.Length; i++)
{

bool isFind = false;

 for (int j = 2; j < nums[i]; j++)

{
if (nums[i] % j == 0)
{
isFind = true;
break;
}

}

if (isFind)
{

}
else
{
Console.Write(nums[i] + " ");
} 
}
Console.ReadLine();

 

六、集合

数码:定长(用于保存固定数量的数额卡塔尔国占内部存款和储蓄器少 遍历速度快

集合:不定长(保存的数目数量,能够在程序的施行进度中,不断的爆发变化卡塔 尔(英语:State of Qatar)占内部存款和储蓄器多 遍历速度慢

List集合

创立:定义:List<数据类型>
变量名;

           赋值:变量名 = new
List<数据类型>();
//群集是不定长的所以赋值是无需点名长度,赋值后长度可以生成

           起始化器:变量名 =
new List<数据类型>{成分1,成分2,···,成分n,};

 

操作

1.添比索素:变量名.Add(要抬高的数据卡塔尔国;

List<int> nums = new
List<int> {3,5,7};
nums.Add(1);
nums.Add(3);

2.插入成分:向集中的内定地点插入二个新的要素

变量名.Insert(索引,要插入的多寡卡塔 尔(阿拉伯语:قطر‎;

List<int> nums = neew
List<int> {3,5.7};
nums.Insert(1,10);

3.删减元素:变量名.RemoveAT(索引卡塔尔国;删除钦定索引地方的要素

变量名.Remove(数据);
除去集结中与填写的数量豆蔻梢头致的率先个相称项

List<int> nums = new
List<int> {1,1,2,3,5};
nums.RemoveAt(2);
nums.Remove(1);

4.改变成分:改善成分中某二个值

变量名[索引] = 值;

代码完结

int maxIndex = numbers.Count - 1;
Console.Write("请您输入一个要删除的下标(0-"+maxIndex +")");
int index = int.Parse(Console.ReadLine());
if (index < 0 || index > maxIndex)
{
Console.WriteLine("呀!你输入有误,下标超出范围了,按回车键继续");
Console.ReadLine();
}
else
{
Console.WriteLine("请你重新输入一个新的数字");
int newNum = int.Parse(Console.ReadLine());
numbers[index] = newNum;
}

 

5.拿走成分数量:集结的长度 变量名.Count

小结:在职能上,数组能完结的享有功能集聚都能兑现行反革命之,群集能兑现的一些成效,数据难以达成(数据,
集结, List集合)

c#的联谊类型  

List Queue Stack LinkedList
HashSet 其他

七、foreach循环

代码格式

foreach(数据类型卡塔 尔(阿拉伯语:قطر‎ 变量 in
数组或集合卡塔尔国
{
循环体
}

从数组或会集中,依次收取每生龙活虎项的多少没抽取大器晚成项数据,歌厅数据赋值个循环变量每二回赋值后,运转二回循环体

代码示例

foreach循环现实:功能高

foreach (int item in
numbers)
{

Console.WriteLine(item);
}

for循环现实:功能低

for ( int i = 1; i <
numbers.Length; i++)
{

Console.WriteLine(numbers[i]);
}

foreach和for的对比

foreach:只用于遍历,不可能校勘循环指标,遍历速度快,实行效用高
for:能够用来其它款式的再度行为,在循环体重,能够展开其它操作,遍历速度慢,推行效能低

如供给遍历和烧结,况兼遍历的经过中只须求读取而不会变动,使用foreach循环最合适,反之,则基于要求,选用别的循环(foreach,
for)

八、集合管理器

代码:

ite(item + "t");
}
Console.WriteLine();

}

Console.WriteLine("*********************************************************");
Console.WriteLine("1.添加数据");
Console.WriteLine("2.删除数据");
Console.WriteLine("3.修改数据");
Console.WriteLine("4.升序排序");
Console.WriteLine("5.退出程序");
Console.WriteLine();
Console.Write("t" + "请您老选择一个序号(1-5):");
string input = Console.ReadLine();

if (input == "5")

{
break;
}
else if (input == "1")
{
Console.Write("请输入要添加的数字:");
int num = int.Parse(Console.ReadLine());
numbers.Add(num);
}
else if (input == "2")
{
Console.Write("请你输入要删除的数字:");
int num = int.Parse(Console.ReadLine());
numbers.Remove(num);
}
else if (input == "3")
{
if (numbers.Count == 0)
{
Console.Write("集合中没有要修改的元素哦?按回车键擦亮眼睛重新选择");
Console.ReadLine();

}
else
{
int maxIndex = numbers.Count - 1;
Console.Write("请您输入一个要删除的下标(0-"+maxIndex +")");
int index = int.Parse(Console.ReadLine());
if (index < 0 || index > maxIndex)
{
Console.WriteLine("呀!你输入有误,下标超出范围了,按回车键继续");
Console.ReadLine();
}
else
{
Console.WriteLine("请你重新输入一个新的数字");
int newNum = int.Parse(Console.ReadLine());
numbers[index] = newNum;
}
}
}
else if (input == "4")
{

for (int i = 0; i < numbers.Count - 1; i++)
{
for (int j = i + 1; j < numbers.Count; j++)
{ 
if(numbers [i]>numbers [j])
{
int temp = numbers[i];
numbers[i] = numbers [j];
numbers[j] = temp;
}
}
}
}
else
{ 
}
Console.Clear();
}

 

全日激励自个儿:

 

       埋头读书,抬头做人!

 

  不登高山不知天之高也,不临深溪不知地之厚也

 

  懦弱的人只会犹豫,莽撞的人必须要引为烧身,唯有真正勇敢的人能力所向无敌

 

  大家这一个世界,从不会给三个悲怆的落伍者颁发奖牌。

 

  海浪的风格,就是累累次被礁石击碎又超级多闪地扑向礁石、

 

  鞋底磨穿了,不对等路走到了头。

 

  松驰的琴弦,永久奏不出时期的强音。

 

  躺在被窝里的人,并不认为太阳的温暖。

 

  不萧规曹随,不甘于平庸,就恐怕在勇于进取的创新特出成品中奏响人生壮美的乐间。

 

  不去耕耘,不去播种,再肥的良田也长不出庄稼,不去激昂,不去成立,再美的青春也结不出硕果。