for的冒泡排序练习题
这是一个冒泡排序的方法,请汲取其中的思想。
有一组数: 1,2,3,4,5,6
请将这组数用降序排列。
我们可以将数组里面的数两两相比,如果第二个数比第一个数大,那么将第二个数值与第一个数值交换,然后让其循环比较。
[1,2,3,4,5,6] [2,3,4,5,6,1] [3,4,5,6,2,1] [4,5,6,3,2,1] [5,6,4,3,2,1]
[2,1,3,4,5,6] [3,2,4,5,6,1] [4,3,5,6,2,1] [5,4,6,3,2,1] [6,5,4,3,2,1]
[2,,1,4,5,6] [3,4,2,5,6,1] [4,5,3,6,2,1] [5,6,4,3,2,1] [6,5,4,3,2,1]
[2,3,,5,6] →→→→ [3,4,5,2,6,1] →→→→ [4,5,6,3,2,1] →→→→[5,6,4,3,2,1] →→→→ [6,5,4,3,2,1]
[2,3,4,5,1,6] [3,4,5,6,2,1] [4,5,6,3,2,1] [5,6,4,3,2,1] [6,5,4,3,2,1]
[2,3,4,5,6,1] [3,4,5,6,2,1] [4,5,6,3,2,1] [5,6,4,3,2,1] [6,5,4,3,2,1]
我们可以先定义一个数组n[]将数据赋予n[]; 通过数组运行循环下标来控制数据比较,既n[0]<n[1];这样我们就得到了判定条件,既
if(n[0]<n[1])
{
int m = 0;
m=n[0];
n[0] = n[1];
n[1] = m;
}
在图中红字可以看出 我们通过两位数比较n[0]<n[1]→n[1]<n[2]→n[2]<n[3]→n[3]<n[4]→n[4]<n[5]既n[i]<n[i+1] 循环。
这里我们输入了6个数比较了5次,那么长度就是(n.length-1)。
得到方法:
static void Main(string[] args)
{
int[] n=new int[]{1,2,3,4,5,6}; //定义一个数组
for (int i = 0; i < n.Length-1; i++) //一共比较了几轮
{
for (int j = 0; j < n.Length - 1; j++) //一轮中比较几次
{
if (n[j]<n[j+1])
{
int m = 0;
m=n[j];
n[j] = n[j + 1];
n[j+ 1] = m;
}
}
}
//for (int k = 0; k < n.Length; k++)
//{
// Console.WriteLine(n[k]);
//}
foreach (int item in n) //用for和foreach都行,经过上面的步骤我们已经把n重新排序好了,输出n。
Console.WriteLine(item);
Console.ReadLine();
}
还一种快速方法供大家参考:
static void Main(string[] args)
{
int[] n=new int[]{1,2,3,4,5,6};
for (int i = 0; i < n.Length-1; i++)
{
for (int j = i; j < n.Length - 1; j++)
{
if (n[j]<n[j+1])
{
int m = 0;
m=n[i];
n[i] = n[j + 1];
n[j+ 1] = m;
}
}
}
foreach (int item in n)
Console.WriteLine(item);
Console.ReadLine();
for的冒泡排序练习题的更多相关文章
- C语言折半查找法练习题冒泡排序
C语言折半查找法练习题 折半查找法: 折半查找法是效率较高的一种查找方法.假设有已经按照从小到大的顺序排列好的五个整数num[0]~num[4],要查找的数是key,其基本思想是: 设查找数据的范围下 ...
- Python3练习题 006 冒泡排序
import random a = [random.randint(1,100) for i in range(10)]def bu(target): length = len(target) whi ...
- VBS练习题
练习题: 1.输入3个数,输出其中最大的那个值. Option Explicit Dim intA,intB,intC intA=CInt(InputBox("请输入a:")) i ...
- js部分---数组及练习题;
数据存储--数组: 强类型语言数组 1.同一类型的数据存储的集合,在内存中是连续的 2.定义的时候需要制定长度 弱类型语言数组 1.可以存储任意类型的数据 2.在内存中不连续,不需要制定长度 定义一个 ...
- c#部分---一维数组、冒泡排序、foreach的用法
一维数组:2016-10-14 定义方式:{定义的时候,需要数据类型.长度!} 1.int []aa=new int [5]; 表示数组里面有5个字符: 2.int []aa=new int []{ ...
- Java数组练习题小结
//2015/07/07 //Java数组小小练习题 /* 3. 写一个函数,计算一个整数数组的平均值 4. 自定义一个整数数组a,读入一个整数n,如果n 在数组中存在,则输出n 的下标:如果不存在, ...
- C#基础——数组(冒泡排序)
数组 所谓数组,就是相同数据类型的元素按一定的顺序的集合,就是把有限个类型相同的变量用一个名字来命名,然后用编号区分他们的变量的集合,这个名字称为数组名,编号称为下标.组成数组的各个变量称为数组的分量 ...
- 从零开始学习PYTHON3讲义(八)列表类型跟冒泡排序
<从零开始PYTHON3>第八讲 前面我们见过了不少的小程序,也见过了不少不同类型的变量使用的方法.但目前我们涉及到的,还都是单个的变量和单个的立即数.以变量来说,目前我们见到的,基本都 ...
- python3编程练习题
记录一些基础编程练习题和一些遇见的坑 1)输出0到100的数字,如果数字是3的倍数输出Fizz,5的倍数输出Buzz.同时是3和5的倍数输出FizzBuzz,其他情况则打印原数字 for i in r ...
随机推荐
- js计算在线时长
后台传来毫秒,前台转换成对应的时分秒 //在线时长 function longTime(seconds){ //总秒数 //seconds=seconds/1000; //得到小时 var hour ...
- JavaScript实现字符串的contains函数
JavaScript实现字符串的contains函数 / * * string:原始字符串 * substr:子字符串 * isIgnoreCase:忽略大小写 * / function co ...
- IOS开发中与设计沟通之字体大小转换
px:相对长度单位.像素(Pixel).pt:绝对长度单位.点(Point).1in = 2.54cm = 25.4 mm = 72pt = 6pc 具体换算是: Points Pixels Ems ...
- SQLServer 批量插入数据的两种方法
SQLServer 批量插入数据的两种方法-发布:dxy 字体:[增加 减小] 类型:转载 在SQL Server 中插入一条数据使用Insert语句,但是如果想要批量插入一堆数据的话,循环使用Ins ...
- MongoDB配置文件YAML-based选项全解
配置文件部分 MongoDB引入一个YAML-based格式的配置文件.2.4版本以前的仍然兼容. 我的mongodb配置文件: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 ...
- BeatifulSoup文档地址
http://www.crummy.com/software/BeautifulSoup/bs4/doc/index.zh.html
- Android Service 与 Thread 的区别
Ref:http://blog.csdn.net/jiangwei0910410003/article/details/17008687 1). Thread:Thread 是程序执行的最小单元,它是 ...
- window 环境安装MongoDB
强制安装mongodb服务 命令 sc create MongoDB binPath= "D:\MongoDB\Server\3.2\bin\mongod.exe --service --d ...
- ssh -v root@xxxxx 显示登录的细节
[root@ok .ssh]# ssh -v root@10.100.2.84 OpenSSH_5.3p1, OpenSSL Feb debug1: Reading configuration dat ...
- Delphi中的接口和抽象类
参考:http://blog.csdn.net/xinzheng_wang/article/details/6058643 接口:Interface Delphi中接口中的关键字Interface,但 ...