关闭

算法提高 ADV-131 选择排序

标签: java数据结构算法蓝桥杯
49人阅读 评论(0) 收藏 举报
分类:
选择排序
问题描述
  排序,顾名思义,是将若干个元素按其大小关系排出一个顺序。形式化描述如下:有n个元素a[1],a[2],…,a[n],从小到大排序就是将它们排成一个新顺序a[i[1]]<a[i[2]]<…<a[i[n]]
  i[k]为这个新顺序。
  选择排序的思想极其简单,每一步都把一个最小元素放到前面,如果有多个相等的最小元素,选择排位较考前的放到当前头部。还是那个例子:{3 1 5 4 2}:
  第一步将1放到开头(第一个位置),也就是交换3和1,即swap(a[0],a[1])得到{1 3 5 4 2}
  第二步将2放到第二个位置,也就是交换3和2,即swap(a[1],a[4])得到{1 2 5 4 3}
  第三步将3放到第三个位置,也就是交换5和3,即swap(a[2],a[4])得到{1 2 3 4 5}
  第四步将4放到第四个位置,也就是交换4和4,即swap(a[3],a[3])得到{1 2 3 4 5}
  第五步将5放到第五个位置,也就是交换5和5,即swap(a[4],a[4])得到{1 2 3 4 5}
  输入n个整数,输出选择排序的全过程。
  要求使用递归实现。
输入格式
  第一行一个正整数n,表示元素个数
  第二行为n个整数,以空格隔开
输出格式
  共n行,每行输出第n步选择时交换哪两个位置的下标,以及交换得到的序列,格式:
  swap(a[i],a[j]):a[0] … a[n-1]
  i和j为所交换元素的下标,下标从0开始,最初元素顺序按输入顺序。另外请保证i<=j
  a[0]…a[n-1]为交换后的序列,元素间以一个空格隔开
样例输入
5
4 3 1 1 2
样例输出
swap(a[0], a[2]):1 3 4 1 2
swap(a[1], a[3]):1 1 4 3 2
swap(a[2], a[4]):1 1 2 3 4
swap(a[3], a[3]):1 1 2 3 4
swap(a[4], a[4]):1 1 2 3 4
数据规模和约定
   n<=100
  整数元素在int范围内

import java.util.Arrays;
import java.util.Scanner;

public class Main {
	public static void main(String[] args) {
		Scanner scanner = new Scanner(System.in);
		int totalNumber = scanner.nextInt();
		int [] sortNumbers = new int [totalNumber];
		for (int index = 0; index < sortNumbers.length; index++) {
			sortNumbers[index] = scanner.nextInt();
		}
		
		printSelectSortStep(sortNumbers);
	}

	private static void printSelectSortStep(int[] sortNumbers) {
		for (int i = 0; i < sortNumbers.length; i++) {
			int min = sortNumbers[i];
			int flag = i;
			for (int j = i; j < sortNumbers.length; j++) {
				if(sortNumbers[j] < min){
					min = sortNumbers[j];
					flag = j;
				}
			}
			sortNumbers[flag] = sortNumbers[i];
			sortNumbers[i] = min;
			System.out.println("swap(a["+i+"], a["+flag+"]):"+Arrays.toString(sortNumbers).replaceAll("[\\[\\],]", ""));
		}
	}
	
}


  
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

算法提高 选择排序( 递归算法)

1221: 算法提高 选择排序 时间限制: 1 Sec  内存限制: 128 MB 提交: 1  解决: 1 [提交][状态][讨论版] 题目描述 排序,顾名思义,是将若干个元素按其大小...
  • xunalove
  • xunalove
  • 2017-02-12 12:57
  • 1598

冒泡排序法、选择排序法、快速排序法三者的效率对比,包括数组的保存与加载

main函数: #include "stdafx.h" #include "TestSonikk.h" #include "UTime.h" int _tmain(int argc, _TCHA...
  • sonikk
  • sonikk
  • 2014-08-26 15:31
  • 3189

蓝桥杯练习系统OJ题解目录

基础练习 蓝桥杯 BASIC-27 基础练习 2n皇后问题 蓝桥杯 BASIC-18 基础练习 矩形面积交 蓝桥杯BASIC-28 基础练习 Huffuman树 蓝桥杯 BASIC-21 基础练习 ...
  • liuchuo
  • liuchuo
  • 2016-08-04 02:05
  • 1939

蓝桥杯 ADV-131算法提高 选择排序

问题描述   排序,顾名思义,是将若干个元素按其大小关系排出一个顺序。形式化描述如下:有n个元素a[1],a[2],…,a[n],从小到大排序就是将它们排成一个新顺序a[i[1]]   i[k]为...
  • liuchuo
  • liuchuo
  • 2016-07-21 23:39
  • 321

Java选择排序算法源码

  • 2013-12-31 21:53
  • 3KB
  • 下载

选择排序算法

  • 2014-03-25 14:36
  • 1.02MB
  • 下载

Java 选择排序 算法

  • 2014-07-21 17:15
  • 4KB
  • 下载

直接插入和选择排序算法

  • 2012-04-01 17:52
  • 1KB
  • 下载

C语言---选择排序算法源代码

  • 2011-11-16 13:33
  • 1KB
  • 下载

冒泡、快排、插入、合并、选择排序算法集锦

  • 2014-05-02 12:20
  • 268KB
  • 下载
    个人资料
    • 访问:14851次
    • 积分:1592
    • 等级:
    • 排名:千里之外
    • 原创:152篇
    • 转载:1篇
    • 译文:0篇
    • 评论:0条