选择排序与冒泡排序(c语言+Java语言)
选择排序 O(n2)
首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置。
再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾。
重复第二步,直到所有元素均排序完毕。

例、/*选择排序(从小到大排列) O(n)
1 5 8 7 2 4 9 3 0 6
*0 5 8 7 2 4 9 3 *1 6
0 *2 8 *7 5 4 9 3 1 6
0 *1 8 7 5 4 9 3 *2 6
0 1 *7 8 *5 4 9 3 2 6
0 1 *5 8 7 *4 9 3 2 6
0 1 *4 8 7 *5 9 3 2 6
0 1 *3 8 7 5 9 *4 2 6
0 1 *2 8 7 5 9 4 *3 6
以此类推………………
*/
C语言代码演示
#include<stdio.h>
main() {
int arr[10] = {1, 5, 8, 7, 2, 4, 9, 3, 0, 6};
for (int i = 0; i < 9; i++) {
for (int j = i + 1; j < 10; j++) {
if (arr[i] > arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
//输出结果
for (int i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
}
*c语言通用代码
#include<stdio.h>
main() {
int arr[N] = {};
for (int i = 0; i < N-1; i++) {
for (int j = i + 1; j < N; j++) {
if (arr[i] > arr[j]) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
}
}
//输出结果
for (int i = 0; i < N; i++) {
printf("%d ", arr[i]);
}
}
Java代码演示//运行时间2600纳秒
public class SelectionSort {
public static void main(String[] args) {
int []arr={1, 5, 8, 7, 2, 4, 9, 3, 0, 6};
selectionSort(arr);//调用选择排序的函数
for(int i=0;i< arr.length;i++)
System.out.print(arr[i]+" ");
}
public static void selectionSort(int []arr){
long startTime = System.nanoTime();//开始时间
for (int i = 0; i < arr.length-1; i++) {
int min=i;//记录最小值下标
for (int j=i+1;j< arr.length;j++){
if(arr[j]<arr[min])
min=j;// 遍历 i+1~length 的值,找到其中最小值的位置
}
if(i!=min){// 交换当前索引 i 和最小值索引 min 两处的值
int temp=arr[i];
arr[i]=arr[min];
arr[min]=temp;
}
}
long overTime = System.nanoTime();//结束时间
System.out.println("程序运行时间为:"+(overTime-startTime)+"纳秒");
}
}
冒泡排序
比较相邻的元素。如果第一个比第二个大,就交换他们两个。
对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。这步做完后,最后的元素会是最大的数。
针对所有的元素重复以上的步骤,除了最后一个。
持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。

例、/* 冒泡排序(从小到大排列)
每一次遍历都把最大的排在最后
1 5 8 7 2 4 9 3 0 6
1 5
5 8
7 8
2 8
4 8
8 9
3 9
0 9
6 9
*1 5 7 2 4 8 3 0 6 9 第一次遍历
1 5
5 7
2 7
4 7
7 8
3 8
0 8
6 8
8 9
*1 5 2 4 7 3 0 6 8 9 第二次遍历
1 5
2 5
4 5
5 7
3 7
0 7
6 7
7 8
8 9
*1 2 4 5 3 0 6 7 8 9 第三次遍历
1 2
2 4
4 5
3 5
0 5
5 6
6 7
7 8
8 9
*1 2 4 3 0 5 6 7 8 9 第四次遍历
以此类推………………
*/
C语言的代码演示
#include<stdio.h>
main(){
int arr[10]={1,5,8,7,2,4,9,3,0,6};
//外层循环表明要排多少次,内层循环表示比较的两个数
for(int i=0;i<9;i++){
//当有n个数时,外层循环需要排n-1次
for(int j=0;j<(10-1)-i;j++){
//(10-1)表示下标,-i表示最大的元素外层循环后,内层循环就不需要比较了
//可以这样理解 j+1不能越界 即j+1<10 所以是j<10-1
if(arr[j]>arr[j+1]){
int temp=arr[j+1];
arr[j+1]=arr[j];
arr[j]=temp;
}
}
}
//输出结果
for(int i=0;i<10;i++){
printf("%d ",arr[i]);
}
}
C语言通用代码
#include<stdio.h>
main(){
int arr[N]={};
//外层循环表明要排多少次,内层循环表示比较的两个数
for(int i=0;i<N-1;i++){
//当有n个数时,外层循环需要排n-1次
for(int j=0;j<(N-1)-i;j++){
//(10-1)表示下标,-i表示最大的元素外层循环后,内层循环就不需要比较了
//可以这样理解 j+1不能越界 即j+1<10 所以是j<10-1
if(arr[j]>arr[j+1]){
int temp=arr[j+1];
arr[j+1]=arr[j];
arr[j]=temp;
}
}
}
//输出结果
for(int i=0;i<N;i++){
printf("%d ",arr[i]);
}
}
Java语言演示//运行时间3100纳秒
public class Bubble_Sort {
public static void main(String[] args) {
int[] arr = {1, 5, 8, 7, 2, 4, 9, 3, 0, 6};
BubbleSort(arr);
for (int i=0;i< arr.length;i++)
System.out.print(arr[i]+" ");
}
public static void BubbleSort(int arr[]){
long startTime = System.nanoTime();//开始时间
for (int i=0;i< arr.length-1;i++){
for (int j=0;j< arr.length-1-i;j++){
if (arr[j]>arr[j+1]){
int temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
long overTime = System.nanoTime();//结束时间
System.out.println("程序运行时间为:"+(overTime-startTime)+"纳秒");
}
}
选择排序与冒泡排序(c语言+Java语言)的更多相关文章
- Java-数据结构与算法-选择排序与冒泡排序
Java 选择排序与冒泡排序 1.DataSorter.java public class DataSorter { //冒泡排序法 //主要思路:按升序排序,数组元素两两比较,大的立即排后面 pub ...
- C语言排序算法之简单交换法排序,直接选择排序,冒泡排序
C语言排序算法之简单交换法排序,直接选择排序,冒泡排序,最近考试要用到,网上也有很多例子,我觉得还是自己写的看得懂一些. 简单交换法排序 /*简单交换法排序 根据序列中两个记录键值的比较结果来对换这两 ...
- java 选择排序、冒泡排序、折半查找
public class SortAndSelectDemo{ public static void main(String[] args){ int[] arr = {3, 5, 17, 2, 11 ...
- java 选择排序与冒泡排序
选择排序与冒泡排序的特点与区别 ++++++++++++++++++++++++++++++++++++++++++++++ 选择排序 这一种简单的排序方法,它的基本思想是:R[n]第一次从R[0]~ ...
- 算法——蛮力法之选择排序和冒泡排序c++实现
这次实现的是蛮力法中的两个例子,选择排序法和冒泡排序法,使用的编译环境是vs2013,下面对这两个算法做一个简单介绍,然后是两个算法的c++实现代码. 选择排序法比较的范围是整个列表,每次扫描结束找出 ...
- c语言程序设计案例教程(第2版)笔记(一)—零散、输入输出、最小公倍数、选择排序、冒泡排序
零散知识点: 非格式化输入输出:getchar().putchar() 格式化输入输出 :scanf().printf() 字符串输入输出 :gets() 或 scanf().puts() 或 ...
- 【java基础】选择排序and冒泡排序
前言 : 今天学习的是J2SE视频里的第五章,数组部分,它里面留了一个经典的作业,就是让我们去从1倒9按一定规格排序,这让我想起了学习vb的时候最最让我头疼的两种排序方法,选择排序法 和 冒泡排序法. ...
- Java中选择排序,冒泡排序,插入排序,快速排序
一:冒泡法排序 //冒泡排序 注:从小到大排 //特点:效率低,实现简单 //思想:每一趟将待排序序列中最大元素移到最后,剩下的为新的待排序序列,重复上述步骤直到排完所有元素. 这只是冒泡排序 ...
- 第三节 java 数组(循环遍历、获取数组的最值(最大值和最小值)、选择排序、冒泡排序、练习控制台输出大写的A)
获取数组的最值(最大值和最小值) 思路: 1.获取最值需要进行比较,每一次比较都会有一个较大的值,因为该 值不确定,需要一个变量进行临储. 2.让数组中的每一个元素都和这个变量中的值进行比较,如果大于 ...
- 插入排序,选择排序,冒泡排序等常用排序算法(java实现)
package org.webdriver.autotest.Study; import java.util.*; public class sort_examp{ public static voi ...
随机推荐
- Github 添加贪吃蛇动画
前言 我们都知道,对于Github来说,当你选择你的账户时,可以看到自己的提交记录. 于是就有大神动脑筋了,这些commit记录都是一些豆,如果弄一条蛇来,不就可以搞个贪吃蛇了吗? 有道理有道理,本文 ...
- 2023成都.NET线下技术沙龙圆满结束
2023年4月15日周六,由MASA技术团队和成都.NET俱乐部共同主办的2023年成都.NET线下技术沙龙活动在成都市世纪城新会展中心知域空间举行,共计报名人数90多人,实际到场60多人,13:30 ...
- ShardingJDBC配置
Sharding-JDBC定位为轻量级Java框架,在Java的JDBC层提供的额外服务. 它使用客户端直连数据库,以jar包形式提供服务,无需额外部署和依赖,可理解为增强版的JDBC驱动,完全兼容J ...
- Java中方法的定义及注意事项
一.方法 什么是方法: 方法(method)是程序中最小的执行单元 实际开发中,什么时候用到方法: 重复的代码.具有独立功能的代码可以抽取到方法中 实际开发中,方法有什么好处: 可以提高代码的复用性 ...
- Analysis of Variance ANOVA versus T test 方差分析和T检验
Levels are different groupings within the same independent variable(factor). Eg. if the independent ...
- python pyinstaller库
简要 pyinstaller模块主要用于python代码打包成exe程序直接使用,这样在其它电脑上即使没有python环境也是可以运行的. 用法 一.安装 pyinstaller属于第三方库,因此在使 ...
- 在unity中制作live2d参数的AnimationClip[简单随笔]
假定:已经成功导入模型.相关文档参考:https://github.com/gtf35/live2d_unity_sdk_chinese_document(人力翻译版的Live2d SDK文档) 全部 ...
- [C++核心编程] 4.2、类和对象-对象的初始化和清理
文章目录 4.2 对象的初始化和清理 4.2.1 构造函数和析构函数 4.2.2 构造函数的分类及调用 4.2.3 拷贝构造函数调用时机 4.2.4 构造函数调用规则 4.2.5 深拷贝与浅拷贝 4. ...
- Python 字典定义
字典 能将相关信息关联起来 可存储的信息几乎不受限制 # 案例1 alien_0 = {'color':'green','points':5} print(alien_0['color']) prin ...
- [C++核心编程] 1、内存分区模型
文章目录 1 内存分区模型 1.1 程序运行前 1.2 程序运行后 1.3 new操作符 1 内存分区模型 C++程序在执行时,将内存大方向划分为4个区域 代码区:存放函数体的二进制代码,由操作系统进 ...