广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java实现选择排序
  • 496
分享到

Java实现选择排序

2024-04-02 19:04:59 496人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

问题描述 利用选择排序把一列数组按从小到大或从大到小排序 (一)、选择排序思想 以从小到大为例: 1、第一轮选择,从第一个数开始,依次比较后面所有的数,不断选出当前最小的数,直到选出

问题描述

利用选择排序把一列数组按从小到大或从大到小排序

(一)、选择排序思想

以从小到大为例:

1、第一轮选择,从第一个数开始,依次比较后面所有的数,不断选出当前最小的数,直到选出这一轮最小的数,放到第一位
2、第二轮选择,从第二个数开始,依次比较后面所有的数,不断选出当前最小的数,直到选出这一轮最小的数,放到第二位
3、如此循环,直到所有数从小到大排列

(二)、问题分析

1. 输入数组

根据用户输入的进行排序的数字数量n,建立一个长度为n的数组


public static void main (String[] args){
  int n,m;
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入你想排序的数量n");
        n=sc.nextInt();
        
        int [] arrary = new int[n];
        System.out.println("请输入"+n+"个数,并用空格隔开");
        
        for(int i=0;i<arrary.length;i++){
            arrary[i]=sc.nextInt();
        }

2.输入如何排序

设置两条路径:m=1为从小到大,m=2为从大到小,m=其他 提醒用户重新输入


System.out.println("请问你想:1.从小到大 2.从大到小 排序?");
        m=sc.nextInt();

        while (m!=1 && m!=2 ){
            System.out.println("输入有误请再次输入");
            m = sc.nextInt();
            continue;
        }

3.排序算法

(1)数组长度 arrary.length 也就是用户输入的 n
(2)j 表示第 j +1轮排序,这里面n-1轮排序就已足够
(3)每一轮都有一个当前最小数的索引
(4)初始时索引给第一个位置的数,与之后面的数依次比较,遇到比自己小的数,就把该索引给更小的数
(5)依次比较,直到索引给了这一轮中最小的数
(6)再把该数放在第一个位置,即交换拿到了索引的位置的数与第一个数的位置
(7)第二轮索引给第二个位置的数,找到了除了第一个位置的数以外的最小的数,交换拿到了第二轮索引的位置的数与第二个数的位置
(8)较大数与较小数交换位置的经典算法:若a>b; 则c=a; a=b; b=c;
(9)从大到小排序只需把 array[index]>array[k] 换成 array[index]<array[k] 即可
(10)选择进行何种排序,在 if 语句的判断框里加上此时m应该等于的值
(11)因为要先选择进行何种排序,才能进行排序,所以把 m==1 放在 arrary[k]>arrary[k+1] 前面,且用短板与 && ,这样更易于理解(如果m≠1,则直接进行else if 的语句)
(12)也可以 m==1 & array[index]>array[k] 或 array[index]>array[k] & m==1,但不能 array[index]>array[k] && m==2。


for(int j=0;j<array.length-1;j++){
            int index=j;
            for(int k=j;k<array.length;k++){

                if(m==1 && array[index]>array[k]){
                    index=k;
                }

                if(m==2 && array[index]<array[k]){
                    index=k;
                }

                int a=array[j];
                array[j]=array[index];
                array[index]=a;

            }
        }

4.输出数组

由于输出的是一段数组,所以还需要引用一段 for 语句


System.out.print("选择"+m+"的结果为:");
        for(int j=0;j<arrary.length;j++)
            System.out.print(arrary[j]+" ");

(三)、完整代码

把上述代码整理


import java.util.*;
public class Selection {
    public static void main (String[] args){
        int n,m;
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入你想排序的数量n");
        n=sc.nextInt();

        System.out.println("请问你想:1.从小到大 2.从大到小 排序?");
        m=sc.nextInt();

        while (m!=1 && m!=2 ){
            System.out.println("输入有误请再次输入");
            m = sc.nextInt();
            continue;
        }

        int [] array = new int[n];
        System.out.println("请输入"+n+"个数,并用空格隔开");

        for(int i=0;i<array.length;i++){
            array[i]=sc.nextInt();
        }

        for(int j=0;j<array.length-1;j++){
            int index=j;
            for(int k=j;k<array.length;k++){

                if(m==1 && array[index]>array[k]){
                    index=k;
                }

                if(m==2 && array[index]<array[k]){
                    index=k;
                }

                int a=array[j];
                array[j]=array[index];
                array[index]=a;

            }
        }

        System.out.print("选择"+m+"的结果为:");
        for(int j=0;j<array.length;j++)
            System.out.print(array[j]+" ");

    }

}

(四)、运行结果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: Java实现选择排序

本文链接: https://www.lsjlt.com/news/133745.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java实现选择排序
    问题描述 利用选择排序把一列数组按从小到大或从大到小排序 (一)、选择排序思想 以从小到大为例: 1、第一轮选择,从第一个数开始,依次比较后面所有的数,不断选出当前最小的数,直到选出...
    99+
    2022-11-12
  • java怎么实现选择排序
    要实现选择排序,可以按照以下步骤进行:1. 遍历数组,从第一个元素开始,将其视为最小值。2. 依次与后面的元素比较,若有比当前最小值...
    99+
    2023-08-17
    java
  • java选择排序
    基本介绍 选择式排序也属于内部排序法,是从欲排序的数据中,按指定的规则选出某一元素,再依规定交换位置后达到 排序的目的。 选择排序思想: 选择排序(select sorting)也是一种简单的排序方法...
    99+
    2023-10-21
    java 排序算法 算法
  • Java如何实现冒泡排序与选择排序
    小编给大家分享一下Java如何实现冒泡排序与选择排序,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一.冒泡排序1.概念冒泡排序这种排序方法其实关键词就在于冒泡两个...
    99+
    2023-06-22
  • java中怎么实现冒泡排序和选择排序
    这篇文章将为大家详细讲解有关java中怎么实现冒泡排序和选择排序,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、冒泡排序冒泡排序(Bubble Sorting)的基本思想是:通过对待排序序...
    99+
    2023-06-20
  • java 排序算法之选择排序
    目录基本介绍基本思想思路分析代码实现演变过程优化算法函数封装大量数据耗时测试基本介绍 选择排序(select sorting)也属于内部排序法,是从欲排序的数据中,按指定的规则选出来...
    99+
    2022-11-12
  • Java排序算法之选择排序
    目录一、选择排序二、代码实现三、测试一、选择排序 选择排序就是在每一次遍历过程中将数组中值最小的排到当前的第一位。 总共需要(数组长度-1)次遍历,在每次遍历中假定第一位索引的值为最...
    99+
    2022-11-12
  • java排序算法之_选择排序(实例讲解)
    选择排序是一种非常简单的排序算法,从字面意思我们就可以知道,选择就是从未排序好的序列中选择出最小(最大)的元素,然后与第 i 趟排序的第 i-1(数组中下标从 0 开始) 个位置的元素进行交换,第 i 个元素之前的序列就是已经排序好的序列。...
    99+
    2023-05-31
    java 选择排序 算法
  • python选择排序简单实现
    #!/usr/bin/env python3 # -*- coding: UTF-8 -*- # Date:2018-5-27 # Author:AreLIN #选择排序:每次只取一个最大或最小值的索引 import random a ...
    99+
    2023-01-31
    简单 python
  • TypeScript选择排序如何实现
    本文小编为大家详细介绍“TypeScript选择排序如何实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“TypeScript选择排序如何实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一. 选择排序的定义选...
    99+
    2023-07-05
  • java冒泡排序和选择排序详解
    目录1、冒泡排序2、选择排序法总结1、冒泡排序 冒泡排序(Bubble Sorting)的基本思想是:通过对待 排序序列从前向后(从下标较小的元素开始),依次比较相邻元素的值,若发...
    99+
    2022-11-12
  • java排序算法之选择排序详解
    本文实例为大家分享了java排序算法之选择排序的具体代码,供大家参考,具体内容如下 选择排序 选择排序的思路是这样的:首先,找到数组中最小的元素,拎出来,将它和数组的第一个元素交换位...
    99+
    2022-11-12
  • 排序算法图解之Java选择排序
    目录1.选择排序简介2.图解选择排序算法3.选择排序代码实现1.选择排序简介 选择排序(Selection sort)是一种简单直观的排序算法。它的工作原理是:第一次从待排序的数据元...
    99+
    2022-11-13
    Java选择排序 Java 排序
  • python排序算法之选择排序怎么实现
    一、前言初级排序算法是指几种较为基础且容易理解的排序算法。初级排序算法包括插入排序、选择排序和冒泡排序3种。虽然它们的效率相对于高级排序算法偏低,但是在了解初级排序算法之后,再去学习相对复杂的高级排序算法会容易许多。二、描述选择排序表示从无...
    99+
    2023-05-17
    Python
  • Python 选择排序中的树形选择排序
    目录1、引言2、问题描述3、解决方案4、结语1、引言 选择排序里面主要讲了三个排序,分别是简单选择排序、树形选择排序、堆排序。今天这篇文章主要讲树形选择排序,树形选择排序也被称为锦标...
    99+
    2022-11-12
  • 详解Java之冒泡排序与选择排序
    目录一.冒泡排序1.概念2.图解3.代码的思路4.代码例子二.选择排序1.概念2.图解3.代码的思路总结一.冒泡排序 1.概念 冒泡排序这种排序方法其实关键词就在于冒泡两个字,顾名思...
    99+
    2022-11-12
  • C语言排序算法之选择排序(直接选择排序,堆排序)
    目录前言一、直接选择排序1.1 算法思想1.2 代码实现1.3 直接选择排序的特征总结二、堆排序2.1 什么是堆?2.2 判断是否是堆2.3 向下调整算...
    99+
    2022-11-13
  • JavaScript中怎么实现冒泡排序和选择排序
    本篇文章为大家展示了JavaScript中怎么实现冒泡排序和选择排序,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。算法说明算法(Algorithm)是解决问题的一种...
    99+
    2022-10-19
  • JavaScript中如何实现冒泡排序与选择排序
    JavaScript中如何实现冒泡排序与选择排序,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。1、冒泡排序算法冒泡算法顾名思义,可以将待排...
    99+
    2022-10-19
  • Java选择排序举例分析
    这篇文章主要介绍“Java选择排序举例分析”,在日常操作中,相信很多人在Java选择排序举例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java选择排序举例分析”的疑惑有所帮助!接下来,请跟着小编一起来...
    99+
    2023-06-25
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作