选择排序与冒泡排序(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 ...
随机推荐
- [中间件]Fastjson [转载]
1 Fastjson的安全漏洞 本段摘自: fastjson到底做错了什么?为什么会被频繁爆出漏洞? 前段时间,fastjson被爆出过多次存在漏洞,很多文章报道了这件事儿,并且给出了升级建议. 但是 ...
- abc285G
ABC 285 G - Tatami Solution 网络流 网格图是一个天然二分图, 可以按 横纵坐标之和 的奇偶性将相邻两格分属于左部和右部. 记'?' 或 '2' 的格子为待匹配点, 记横纵坐 ...
- Fatal error: Uncaught SoapFault exception:解决办法
SOAP-ERROR: Parsing WSDL: failed to load external entity Fatal error: Uncaught SoapFault exception: ...
- Go语言网络编程:SSH连接
旨在提升Go语言网络编程能力 SSH是什么? SSH 为 Secure Shell 的缩写,为建立在应用层基础上的安全协议.SSH 是较可靠,专为远程登录会话和其他网络服务提供安全性的协议.利用 SS ...
- 带你用三种不同的工具体验AI作诗
摘要:本实验基于华为云API Arts和API Explorer,向用户介绍诗歌生成API,指导用户使用华为云工具,体验AI作诗的过程. 本文分享自华为云社区<AI语言能力体验:通过三种不同的工 ...
- 用PHPstudy nginx 配置tp6 隐藏访问链接中的index.php
在server 里面加上如下这个判断就好了 if (!-e $request_filename){ rewrite ^(.*)$ /index.php?s=$1 last; break; 配置在对应网 ...
- CVE-2015-5254漏洞复现
1.漏洞介绍. Apache ActiveMQ 是美国阿帕奇(Apache)软件基金会所研发的一套开源的消息中间件,它支持 Java 消息服务,集群,Spring Framework 等.Apache ...
- Appweb配置
Appweb配置 具体配置网页=> https://www.embedthis.com/appweb/doc/users/configuration.html 具体参 ...
- 关于为element Tree组件实现仿文件夹效果及右键菜单
<template> <div class="custom-tree-container" @contextmenu.native="handlePas ...
- Ffmpeg 视频压缩的几个关键参数
Ffmpeg的视频操作官网文档:https://ffmpeg.org/ffmpeg-filters.html#Video-Filters 视频压缩用到的参数主要为以下几个: 文件路径:-i 输入文件的 ...