zoukankan      html  css  js  c++  java
  • golang 冒泡排序实现

    排序,顾名思义,就是把一坨数字按照某种特定的顺序排列好了,比如从小到大又或者从大到小。

    冒泡排序,冒泡嘛,形象一点儿,就是一个个泡泡往上涌,然后和“相邻的泡泡”比试,最后最小的泡泡浮到了水面上。既然是想要让小的从底部都涌到上面,那么为何不尝试一下最后往前呢?

    package main
    
    import(
    	"fmt"
    )
    
    //冒泡排序常规排序
    /*func Bubblesort(arr *[5]int)  {
    	
    	fmt.Println("排序前arr=",(*arr))
    	temp:=0
    	for i:=0; i<len(*arr)-1;i++{
    		for j:=0;j<len(*arr)-1-i;j++{
    			if(*arr)[j] > (*arr)[j+1]{
    				temp = (*arr)[j]
    				(*arr)[j] = (*arr)[j+1]
    				(*arr)[j+1] = temp
    			}
    		}
    	}
    
    	fmt.Println("排序后arr=",(*arr))
    }*/
    //冒泡排序 比上者排序更有优势,特殊情况arr:=[5]int{7,10,20,35,98}这种情况就无需所有再次遍历
    func Bubblesort(arr *[5]int)  {
    	fmt.Println("排序前arr=",(*arr))
    	temp:=0
    	swap:=true
    	for i:=0; i<len(*arr)&& swap==true;i++{
    		swap=false
    		for j:=len(*arr)-1; j > i; j--{
    			if(*arr)[j] < (*arr)[j-1]{
    				temp = (*arr)[j]
    				(*arr)[j] = (*arr)[j-1]
    				(*arr)[j-1] = temp
    				swap = true
    			}
    		}
    	}
    
    	fmt.Println("排序后arr=",(*arr))
    }
    
    func main()  {
    	arr:=[5]int{20,98,10,35,7}
    	Bubblesort(&arr)
    }
    

      

  • 相关阅读:
    pdf文件怎么转换成word文档
    数据库的发展历程
    数据库的三级模式
    数据库概述
    时间序列的自回归模型—从线性代数的角度来看
    数据清洗
    sql commit的三种方式
    数据库标准语言SQL((Structured Query Language)
    正则化推导转载
    leetcode刷题
  • 原文地址:https://www.cnblogs.com/setevn/p/14277468.html
Copyright © 2011-2022 走看看