【Python : 选择排序(1)】教程文章相关的互联网学习教程文章

数据结构精要------直接选择和堆排序算法

上篇总结中主要实践了算法的内排序的交换排序,那么接下来我们继续实践选择排序的两种:直接选择和堆排序算法。-----直接选择排序package com.sort;/*** 直接选择排序算法* @author weixing-yang** 算法思路:* 首先找出最大元素,将其与a[n-1]位置置换。* 然后在余下的n-1个元素中寻找最大元素,将其与a[n-2]位置置换。* 如此进行下去,知道n个元素排序完成。*/ public class SelectSort {public void selectSort(int[] arr, i...

堆排序【代码】

堆排序堆排序以二叉形式。以数组形式表示。a[1] 是二叉堆的跟结点,每个结点的有左右子结点。规定每个结点的值大于其子节点的堆叫最大堆,小于的叫最小堆。无序数组通过建堆的方式建立成一个最大或最小堆。算了 ,说不清,上代码。代码:#include <bits/stdc++.h> using namespace std; const int MAXN = 100; int a[MAXN] = {0,4,1,3,2,16,9,10,14,8,7};//10 int n = 10;//数的个数void Max_Heap(int x,int n) {//维护根节点为x的...

HDU 3743 Frosh Week(归并排序求逆序对)【代码】【图】

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3743 题目意思就是给你一个长为n的序列,让你求逆序对.我用的是归并排序来求的.归并排序有一个合并的过程,分前后两段,当a[i] > a[j]时,说明a[j]比前面那段啊[i],a[i+1],a[i+2]....,a[mid],比这些都要小,所以总逆序对数要加上mid-i+1. 1// File Name: HDU3743.cpp2// Author: xiaxiaosheng3// Created Time: 2015年03月09日 星期一 21时54分45秒 4 5 #include<vector>6 #includ...

HDU 4857 逃生 拓扑排序好题 第一次做CLJ出的题【代码】【图】

逃生Problem Description糟糕的事情发生啦,现在大家都忙着逃命。但是逃命的通道很窄,大家只能排成一行。现在有n个人,从1标号到n。同时有一些奇怪的约束条件,每个都形如:a必须在b之前。同时,社会是不平等的,这些人有的穷有的富。1号最富,2号第二富,以此类推。有钱人就贿赂负责人,所以他们有一些好处。负责人现在可以安排大家排队的顺序,由于收了好处,所以他要让1号尽量靠前,如果此时还有多种情况,就再让2号尽量靠前,...

js 中的冒泡排序 和 快速排序【代码】【图】

冒泡排序 var arr = [2,43,35463,232,2,645,4567,5];function bubbleSort(arr) {for (let i = 0 ; i < arr.length-1 ; i++) {for (let j = 0 ; j < arr.length - 1 - i ; j++) {if(arr[j] > arr[j+1]){var temp = arr[j];arr[j] = arr[j+1];arr[j+1] = temp;}}}}bubbleSort(arr);console.log(arr); 2、快速排序var arr = [2,43,35463,232,2,645,4567,5];function quickSort(arr) {//标杆const pivot = arr[0];//比标杆大的数组va...

java实现堆排序

package com.peter.app.hello.heapsort; /** * heap sort * @author Peter.Yu * */ public class HeapSort { public static int COUNT = 0; /** * build heap * @param a * @param size */ public static void buildHeap(int[] a, int size) { for (int i = size / 2; i >= 1; i--) { adjustHeap(a, i, size); } } /** * adjust heap * @param...

归并排序【代码】【图】

归并排序归并排序是采用分治法的一个非常典型的应用。归并排序的思想就是先递归分解数组,再合并数组。将数组分解最小之后,然后合并两个有序数组,基本思路是比较两个数组的最前面的数,谁小就先取谁,取了后相应的指针就往后移一位。然后再比较,直至一个数组为空,最后把另一个数组的剩余部分复制过来即可。 代码实现:def merge_sort(alist):n = len(alist)if n <= 1:return alistmid = n//2left_li = merge_sort(alist[:mid])...

排序算法【代码】

#define LENGTH(array) ( (sizeof(array)) / (sizeof(array[0])) ) #define swap(a,b) do{a=a+b;b=a-b;a=a-b;}while(0) //两个数相同时 会导致结果为0一、插入排序1、直接插入排序 1/**2** 直接插入排序(插入到准确的位置) 不利于二分查找 直接遍历3** 时间复杂度:比较和移动和平均时间复杂度为O(n^2) 适合基本有序的序列,此时复杂度接近O(n)4** 空间复杂度:O(1)5** 稳定性:稳定6**/ 7void InsertSort(int a[], in...

终极快速排序【图】

1.终极快速正序排序 Arrays.sort()方法输出:23456789ABCDEF2.终极快速逆序排序 Collections.reverse()方法输出:94726853FDEACB输出:98765432FEDCBA 原文:https://www.cnblogs.com/justBobo/p/10661407.html

php不用内置函数对数组排序的两个算法代码

一朋友找工作遇到的试题,备注一下。 极有可能今后我也会遇到的。 问题:php不用内置函数对数组排序,可能是降序或者升序 第一种方法:传说中的冒泡法 复制代码 代码如下:function arraysort($data, $order = ‘asc‘) { //asc升序 desc降序 $temp = array (); $count = count ( $data ); if ($count <= 0) return false; //传入的数据不正确 if ($order == ‘asc‘) { for($i = 0; $i < $count; $i ++) { for($j = $count - 1; $j...

算法——快速排序【代码】

快速排序# 快速排序def main(ary):# D&C思想:基线条件if len(ary) < 2:return aryelse:base = ary[0]left = [i for i in ary[1:] if i <= base]right = [i for i in ary[1:] if i > base]return main(left) + [base] + main(right)ary = [1, 34, 22, 54, 66, 22, 12, 25, 78, 91, 41, 1, 34, 22, 54, 66, 22, 12, 25, 78, 91, 41, 1, 34, 22, 54, 66, 22, 12, 25, 78, 91, 41] res = main(ary) print(res) """ [1, 1, 1, 12, 12, ...

面试复习(C++)之快速排序【代码】

#include <iostream>usingnamespace std;void Quicksort(int *a,int low,int high) {if(low>high){return;}int i=low;int j=high;int key=a[i];while(i<j){while(i<j&&a[j]>=key){j--;}a[i]=a[j];while(i<j&&a[i]<=key){i++;}a[j]=a[i];}a[i]=key;Quicksort(a,low,i-1);Quicksort(a,i+1,high); }int main() {int n=5;int a[10];for(int i=0;i<n;i++){cin>>a[i];}Quicksort(a,0,n);for(int j=0;j<n;j++){cout<<a[j]<<"";}return0; }...

温故之 “插入排序”【代码】

概念:将一个数据插入已经排好序的有序数组中,从而得到一个新的多一个数据的有序数组。概念理解~~将要排序的是一个乱的数组int[] arrays = {3, 2, 1, 3, 3}; 在未知道数组元素的情况下,我们只能把数组的第一个元素作为已经排好序的有序数据,也就是说,把{3}看成是已经排好序的有序数据第一趟排序: 用数组的第二个数与第一个数(看成是已有序的数组)比较如果比第一个数大就不用管如果比第一个数小,将第一个数往后退一步,将第二...

归并排序【代码】

转 白话经典算法系列之五 归并排序的实现#include <iostream> using namespace std;//将有二个有序数列a[first...mid]和a[mid...last]合并。 void mergearray(int a[], int first, int mid, int last, int temp[]) { int i = first, j = mid + 1; int m = mid, n = last; int k = 0; while (i <= m && j <= n) { if (a[i] <= a[j]) temp[k++] = a[i++]; else temp[k++] = a[j++]; } while (i <= m) temp[k++] = ...

JS实现快速排序算法【代码】

以下贴出两种实现方式,结果一样,但有些许的差别:第一种: 1 <script type="text/javascript">2var arr=[6,7,8,3,4,5,9];3function quicksort(left,right){4if(left>right){5return ;6 }7var temp=0;8var i=right;9var j=left; 10 temp=arr[left]; 11while(arr[i]>arr[left]){ 12 i--; 13 } 14while(arr[j]<=arr[left]){ 15 j++...