zoukankan      html  css  js  c++  java
  • 排序与查找

    排序与查找

    排序分类

    内部排序

    将要处理的数据都加载到内存中进行排序:交换式排序,选择式排序,插入式排序

    外部排序

    数据过大无法全部加载到内存中,需借助外部存储器:合并排序,直接合并排序

    冒泡排序

    查找

    顺序查找

    直接找值,一般
    index= -1,借助index的值确定有没有找到(推荐)

    二分查找(对有序数组)

    二维数组(五子棋游戏)

    内存存在形式(重点)

    使用方式(类似于一维数组)四种

    		定义时初始化:var arr3 [2][3]int = [2][3]int{{1,2,3},{4,5,6}} 
    		var 数组名 [大小][大小]类型 = [大小][大小]类型{{初值..},{初值..}}
    		var 数组名 [大小][大小]类型 = [...][大小]类型{{初值..},{初值..}}
    		var 数组名 = [大小][大小]类型{{初值..},{初值..}}
    		var 数组名 = [...][大小]类型{{初值..},{初值..}}
    		煮:有一个不能写成..(第二个).
    

    遍历:略

    案例

    ​ 定义二维数组,用于保存三个班,每个班五名同学成绩,
    并求出每个班级平均分、以及所有班级平均分

    package main
    import (
    	"fmt"
    )
    
    func main() {
    
    	/*
    	定义二维数组,用于保存三个班,每个班五名同学成绩,
    	并求出每个班级平均分、以及所有班级平均分
    	*/
    
    	//1.定义一个二维数组
    	var scores [3][5]float64
    	//2.循环的输入成绩
    	for i := 0; i < len(scores); i++ {
    		for j := 0; j < len(scores[i]); j++ {
    			fmt.Printf("请输入第%d班的第%d个学生的成绩
    ", i+1, j+1)
    			fmt.Scanln(&scores[i][j])
    		}
    	}
    
    	//fmt.Println(scores)
    
    	//3.遍历输出成绩后的二维数组,统计平均分
    	totalSum := 0.0 // 定义一个变量,用于累计所有班级的总分
    	for i := 0; i < len(scores); i++ {
    		sum := 0.0 //定义一个变量,用于累计各个班级的总分
    		for j := 0; j < len(scores[i]); j++ {
    			sum += scores[i][j]
    		}
    		totalSum += sum 
    		fmt.Printf("第%d班级的总分为%v , 平均分%v
    ", i+1, sum, 
    			sum / float64(len(scores[i])))
    	}
    
    	fmt.Printf("所有班级的总分为%v , 所有班级平均分%v
    ", 
    		totalSum, totalSum / 15 )
    }
    
  • 相关阅读:
    复合梯形公式、复合辛普森公式 matlab
    拉格朗日插值和牛顿插值 matlab
    数值分析 最小二乘 matlab
    最短路径Dijkstra matlab
    最小生成数 克鲁斯卡尔 普里姆 matlab
    [ 9.9 ]CF每日一题系列—— 259A黑白棋盘检查问题
    Tarjan求缩点化强连通图
    CF每日一题系列 —— 415A
    [kuangbin]树链剖分 C
    [kuangbin]树链剖分 D
  • 原文地址:https://www.cnblogs.com/ygjzs/p/11779981.html
Copyright © 2011-2022 走看看