选择排序 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语言)的更多相关文章

  1. Java-数据结构与算法-选择排序与冒泡排序

    Java 选择排序与冒泡排序 1.DataSorter.java public class DataSorter { //冒泡排序法 //主要思路:按升序排序,数组元素两两比较,大的立即排后面 pub ...

  2. C语言排序算法之简单交换法排序,直接选择排序,冒泡排序

    C语言排序算法之简单交换法排序,直接选择排序,冒泡排序,最近考试要用到,网上也有很多例子,我觉得还是自己写的看得懂一些. 简单交换法排序 /*简单交换法排序 根据序列中两个记录键值的比较结果来对换这两 ...

  3. java 选择排序、冒泡排序、折半查找

    public class SortAndSelectDemo{ public static void main(String[] args){ int[] arr = {3, 5, 17, 2, 11 ...

  4. java 选择排序与冒泡排序

    选择排序与冒泡排序的特点与区别 ++++++++++++++++++++++++++++++++++++++++++++++ 选择排序 这一种简单的排序方法,它的基本思想是:R[n]第一次从R[0]~ ...

  5. 算法——蛮力法之选择排序和冒泡排序c++实现

    这次实现的是蛮力法中的两个例子,选择排序法和冒泡排序法,使用的编译环境是vs2013,下面对这两个算法做一个简单介绍,然后是两个算法的c++实现代码. 选择排序法比较的范围是整个列表,每次扫描结束找出 ...

  6. c语言程序设计案例教程(第2版)笔记(一)—零散、输入输出、最小公倍数、选择排序、冒泡排序

    零散知识点: 非格式化输入输出:getchar().putchar() 格式化输入输出   :scanf().printf() 字符串输入输出   :gets() 或 scanf().puts() 或 ...

  7. 【java基础】选择排序and冒泡排序

    前言 : 今天学习的是J2SE视频里的第五章,数组部分,它里面留了一个经典的作业,就是让我们去从1倒9按一定规格排序,这让我想起了学习vb的时候最最让我头疼的两种排序方法,选择排序法 和 冒泡排序法. ...

  8. Java中选择排序,冒泡排序,插入排序,快速排序

    一:冒泡法排序  //冒泡排序 注:从小到大排   //特点:效率低,实现简单  //思想:每一趟将待排序序列中最大元素移到最后,剩下的为新的待排序序列,重复上述步骤直到排完所有元素. 这只是冒泡排序 ...

  9. 第三节 java 数组(循环遍历、获取数组的最值(最大值和最小值)、选择排序、冒泡排序、练习控制台输出大写的A)

    获取数组的最值(最大值和最小值) 思路: 1.获取最值需要进行比较,每一次比较都会有一个较大的值,因为该 值不确定,需要一个变量进行临储. 2.让数组中的每一个元素都和这个变量中的值进行比较,如果大于 ...

  10. 插入排序,选择排序,冒泡排序等常用排序算法(java实现)

    package org.webdriver.autotest.Study; import java.util.*; public class sort_examp{ public static voi ...

随机推荐

  1. Redis源码之SDS简单动态字符串

    Redis 是内存数据库,高效使用内存对 Redis 的实现来说非常重要. 看一下,Redis 中针对字符串结构针对内存使用效率做的设计优化. 一.SDS的结构 c语言没有string类型,本质是ch ...

  2. QUIC协议 对比 TCP/UDP 协议

    QUIC协议是HTTP3引入的,所以需要了解HTTP的版本迭代. HTTP1.x 队头阻塞:下个请求必须在前一个请求返回后才能发出,导致带宽无法被充分利用,后续请求被阻塞(HTTP 1.1 尝试使用流 ...

  3. Analysis of Variance ANOVA versus T test 方差分析和T检验

    Levels are different groupings within the same independent variable(factor). Eg. if the independent ...

  4. ES的索引结构与算法解析

    作者:京东物流 李洪吉 提到ES,大多数爱好者想到的都是搜索引擎,但是明确一点,ES不等同于搜索引擎.不管是谷歌.百度.必应.搜狗为代表的自然语言处理(NLP).爬虫.网页处理.大数据处理的全文搜索引 ...

  5. CQOI2013vp记

    新Nim游戏 因为第一次操作与其它操作不同,考虑拿出来单独做,剩下的操作就变成了 Nim游戏 了. 回忆一下 Nim游戏 先手必胜的条件是什么,是所有数的异或和不为 \(0\),那么这题就转化为求原集 ...

  6. 解密Elasticsearch:深入探究这款搜索和分析引擎

    作者:京东保险 管顺利 开篇 最近使用Elasticsearch实现画像系统,实现的dmp的数据中台能力.同时调研了竞品的架构选型.以及重温了redis原理等.特此做一次es的总结和回顾.网上没看到有 ...

  7. pyhton内置函数

    内置函数 1.type(变量名)-> class 查看变量的数据类型 2.print(self, *args, sep=' ', end='\n', file=None) sep:指定多个参数以 ...

  8. Unity快速接入bugly, 支持Unity2021

    鹅厂提供的bugly官方demo工程打包后台也查不到日志,N年不更新(官方已经说不再维护),为此本人做了部分修改测试,提供一个快速接入工程的demo. Unity2021因为版本原因腾讯官方工程不能使 ...

  9. 【已解决】使用代理后,登陆微软账号提示0x800190001

    今天晚上想要登录Onedrive同步文件时,发现怎么都登陆不上去,报出的错误代码是0x80190001,在网上搜索了各种方法,重置网络,重置Onedrive都没什么用,甚至把Onedrive重装了一遍 ...

  10. uni-app Pages.json配置

    https://uniapp.dcloud.net.cn/collocation/pages.html pages.json 文件用来对 uni-app 进行全局配置,决定页面文件的路径.窗口样式.原 ...