算法图解阅读笔记-选择排序

栏目: 编程工具 · 发布时间: 7年前

内容简介:遍历所有元素,挑出最小的元素放在结果集中并删除该元素,直到要排序的数据集中没有元素为止。注意,提取函数时小心删除元素之后,原数组长度受影响,这里使用find_arr设置为不断缩小的结果集。

数组与链表

  • 数组是连续内存的应用方式,它的特点就是所有的单元的内存地址都是连续的,当需要扩展而初始化的内存不足够的时候,就需要重新申请内存。
  • 链表是已上一个元素指向来完成存储的,它在内存的存储是分散的,无论是添加还是删除较数组的最大优势就是都不需要整体动,只需要上一个元素的指向调整就好,缺点就是无法直接通过计算获得某个元素,如果要在链表中查找某一个元素,就需要遍历整个链表(最差情况)

选择排序

遍历所有元素,挑出最小的元素放在结果集中并删除该元素,直到要 排序 的数据集中没有元素为止。

golang版本

package main

import "fmt"

func main() {
    info := []int{12, 3, 54, 6, 6777, 2342, 234, 55, 6, 6777, 34545,}

    for i := 0; i < len(info); i++ {

        for j := 0; j < len(info); j++ {
            if info[j] < info[i] {
                info[i],info[j] = info[j],info[i]
            }
        }
        
    }
    fmt.Println(info)
}

php版本

$arr_info = array(
    10, 5, 12, 5, 67, 8, 45, 3, 11, 66, 442, 2, 34, 2342
);

$result = array();

$find_arr = $arr_info;

for ($i = 0; $i < sizeof($arr_info); $i++) {
    $tmp = 0;
    $smallest = $find_arr[0];
    for ($j = 0; $j < sizeof($find_arr); $j++) {
        if ($smallest > $find_arr[$j]) {
            $smallest = $find_arr[$j];
            $tmp = $j;
        }
    }
    $result[] = $smallest;
    unset($find_arr[$tmp]);
    $find_arr = array_values($find_arr);

}

var_export($result);

注意,提取函数时小心删除元素之后,原数组长度受影响,这里使用find_arr设置为不断缩小的结果集。


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

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

网络、群体与市场

网络、群体与市场

大卫·伊斯利(David Esley)、乔恩·克莱因伯格(Jon Kleinberg) / 李晓明、王卫红、杨韫利 / 清华大学出版社 / 2011-10-1 / CNY 69.00

过去十年来,现代社会中复杂的连通性向公众展现出与日俱增的魅力。这种连通性在许多方面都有体现并发挥着强大的作用,包括互联网的快速成长、全球通信的便捷,以及新闻与信息(及传染病与金融危机)以惊人的速度与强度传播的能力。这种现象涉及网络、动机和人们的聚合行为。网络将人们的行为联系起来,使得每个人的决定可能对他人产生微妙的后果。 本书是本科生的入门教材,同时也适合希望进入相关领域的高层次读者。它从交......一起来看看 《网络、群体与市场》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

随机密码生成器
随机密码生成器

多种字符组合密码