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 ...
随机推荐
- iScroll.js 用法参考 (share)
分享是传播.学习知识最好的方法 以下这篇文章是iScroll.js官网的中文翻译,尽管自己英文不好,但觉得原作者们翻译的这个资料还是可以的,基本用法介绍清楚了.如果你英文比较好的话,可以看看官网的资料 ...
- CCF 最优配餐 (BFS)
问题描述 栋栋最近开了一家餐饮连锁店,提供外卖服务.随着连锁店越来越多,怎么合理的给客户送餐成为了一个急需解决的问题. 栋栋的连锁店所在的区域可以看成是一个n×n的方格图(如下图所示),方格的格点上的 ...
- Gym 100703K Word order 贪心
题目链接 题意:给定一个长度为n的字符串,字符串仅由"F","N","A"三种字符组成,现有一种操作P,即把两个相邻的字符调换位置.要求把所 ...
- Sql order by 和 group BY一起使用时需要注意
ORDER BY 子句中的列必须包含在聚合函数或 GROUP BY 子句中. slect * from table group by class,id order by id slect * from ...
- express响应前端ajax请求
后端其实并不需要知道前端发起的请求是不是ajax,后端只需要响应请求即可.例子: 前端这样写: $('button').on('click', function(event) { event.prev ...
- python基础——迭代器
python基础——迭代器 我们已经知道,可以直接作用于for循环的数据类型有以下几种: 一类是集合数据类型,如list.tuple.dict.set.str等: 一类是generator,包括生成器 ...
- C#命名规范的几点建议
1.最好以<Company>.<Component>做为namespace的格式 2.考虑是否需要将namespace设置为复数,如:FCL中的System.Collectio ...
- shared_ptr 和 unique_ptr
c++11标准废除乐auto_ptr, C++ 标准库智能指针 使用这些智能指针作为将指针封装为纯旧 C++ 对象 (POCO) 的首选项. unique_ptr 只允许基础指针的一个所有者. 除非你 ...
- NYOJ题目840吃花生
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAskAAAKdCAIAAABeSGNbAAAgAElEQVR4nO3dPXKkuvv28f8mnHshjn
- mysql入门语句10条
1,连接数据库服务器 mysql -h host -u root -p xxx(密码) 2,查看所有库 show databases; 3,选库 use 库名 4,查看库下面的表 show ...