选择排序与冒泡排序(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 ...
随机推荐
- Cesium案例(八) Terrain
第一步正常建viewer,需要注意的是官网例子属性值比较老,最新版本的属性值有所差异,全copy官网会无法运行,提示函数未定义. 第一处差异 官网: 1 const viewer = new Cesi ...
- 事实胜于雄辩,苹果MacOs能不能玩儿机器/深度(ml/dl)学习(Python3.10/Tensorflow2)
坊间有传MacOs系统不适合机器(ml)学习和深度(dl)学习,这是板上钉钉的刻板印象,就好像有人说女生不适合编程一样的离谱.现而今,无论是Pytorch框架的MPS模式,还是最新的Tensorflo ...
- day68:Vue:类值操作/style样式操作&v-for&filer/computed/watch&生命周期钩子函数&axios
目录 1.类值操作 :class 2.style操作样式 :style 3:示例:选项卡 @click+:class 4.v-for示例:循环商品显示 5.过滤器:filter 6.计算属性:comp ...
- ChatGPT研究报告:AIGC带来新一轮范式转移
以ChatGPT为代表的AIGC(人工智能生成内容)将成为新一轮范式转移的开始. 本文约4000字,目标是快速建立AIGC知识体系,含有大量的计算专业名词,建议阅读同时扩展搜索. 一.行业现状 1.概 ...
- 【深入浅出Spring原理及实战】「源码调试分析」深入源码探索Spring底层框架的的refresh方法所出现的问题和异常
学习Spring源码的建议 阅读Spring官方文档,了解Spring框架的基本概念和使用方法. 下载Spring源码,可以从官网或者GitHub上获取. 阅读Spring源码的入口类,了解Sprin ...
- Marior去除边距和迭代内容矫正用于自然文档矫正
一.简要介绍 本文简要介绍了论文" Marior: Margin Removal and Iterative Content Rectification for Document Dewar ...
- Python 变量作用域和列表
变量作用域 变量由作用范围限制 分类:按照作用域分类 全局(global):在函数外部定义 局部(local):在函数内部定义 变量的作用范围: 全局变量:在整个全局范围有效 全局碧昂量在局部可以使用 ...
- [C++核心编程] 4.7 多态
文章目录 4.7 多态 4.7.1 多态的基本概念 4.7.2 多态案例一-计算器类 4.7.3 纯虚函数和抽象类 4.7.4 多态案例二-制作饮品 4.7.5 虚析构和纯虚析构 4.7.6 多态案例 ...
- Sementic Kernel 案例之网梯科技在线教育
2023年4月25日,微软公布了2023年第一季度财报,营收528亿美元, 微软CEO纳德称,「世界上最先进的AI模型与世界上最通用的用户界面--自然语言--相结合,开创了一个新的计算时代.」该公司有 ...
- I-o-C 一篇概览
一.ioC 容器和 Bean介绍 IoC(Inversion of Control )也被称之为 DI(dependency injection),名称侧重点略有不同. 所谓控制翻转即对象通过构造函数 ...