数据结构与算法第(2)讲-线性表和排序

本文深入探讨了线性表的两种主要存储方式——顺序存储和链式存储,并对比了它们的特点与优缺点。同时,文章详细介绍了冒泡排序和选择排序这两种基本排序算法的实现过程,以及如何通过优化提高排序效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

线性表是很常见数据结构表的一种,一般又细分为顺序存储和链式存储,前者是以一个连续空间来存储数据,而后者则是用节点来存储数据。

顺序表是有前驱和后驱,我们可以这样描述,a1是a2的前驱,ai+1 是ai的后继,a1没有前驱,an没有后继
n为线性表的长度 ,若n==0时,线性表为空表。优点:尾插效率高,支持随机访问。缺点:中间插入或者删除效率低。
比如常用的数组和ArrayList。

链表是由一个个节点组成的,每一个节点都可以存储自己的数据,节点之间有着单向或者双向的关系,由此分为单向链表和双向链表,在java中LinkedList就是一个双向链表,根据LinkedList源码中我们可以发现链表可操作性非常好,虽然尾插效率相比顺序表低,但是插入和删除效率却比顺序表好太多。

顺序表的遍历都是用蛮力法的思想。蛮力法(brute force method,也称为穷举法或枚举法)是一种简单直接地解决问题的方法,常常直接基于问题的描述,所以,蛮力法也是最容易应用的方法。但是,用蛮力法设计的算法时间特性往往也是最低的,典型的指数时间算法一般都是通过蛮力搜索而得到的 。(即输入资料的数量依线性成长,所花的时间将会以指数成长)

下面就具体讲两个排序:

1.冒泡排序

    /**
    * 冒泡排序(适合数据量少)
    */
    public void maopaoSort(int[] src){
        for (int i=src.length-1;i>0;i--){
            boolean flag=true;   //通过标记优化第二层循环执行次数
            for (int j=0;j < i;j++){
                if(src[j] > src[j+1]){
                    int x = src[j];
                    src[j] = src[j+1];
                    src[j+1] = x;
                    flag=false;
                }
            }
            if(flag){
                break;
            }
        }
    }

2.选择排序


    /**
    * 选择排序(适合数据量少)
    */
    public void selectSort(int[] array){
        for (int i=0;i<array.length-1;i++) {
            int index = i;
            for (int j = i + 1; j < array.length; j++) {
                if (array[j] < array[index]) {
                    index = j;
                }
            }
            if (index != i) {  //优化 如果不是最小的就不需要交换
                int temp = array[index];
                array[index] = array[i];
                array[i] = temp;
            }
        }
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值