顺序表

109 篇文章 0 订阅

头文件 order.h

# ifndef __ORDER_H__
# define __ORDER_H__




typedef int DataType;
#define MAX_SIZE 10 


//++++++++++++++++++++++++++++++++++++++++++++++++++++++=
//head
# include <stdio.h>
# include <assert.h>
# include <memory.h>


//++++++++++++++++++++++++++++++++++++++++++++++++++++++++=
//结构
typedef struct SeqList
{
    DataType _array[MAX_SIZE];
    int _size; // 表示顺序表中有效元素的个数 
}SeqList, *PSeqList;

typedef struct SeqList* PSeqList;
typedef struct SeqList SeqList;
SeqList s;

///////////////////////////////////////////////////////////////////// 
// 函数声明

//测试函数
void test();
// 顺序表的初始化 
void SeqListInit(PSeqList ps);

// 顺序表的尾插 
void SeqListPushBack(PSeqList ps, DataType data);

// 顺序表的尾删 
void SeqListPopBack(PSeqList ps);

// 顺序表的头插 
void SeqListPushFront(PSeqList ps, DataType data);

// 顺序表的头删 
void SeqListPopFront(PSeqList ps);

// 顺序表pos位置插入元素data 
void SeqListInsert(PSeqList ps, int pos, DataType data);

// 删除顺序表pos位置元素 
void SeqListErase(PSeqList ps, int pos);

// 移除顺序表中第一个值为data的元素 
void Remove(PSeqList ps, DataType data);

// 移除顺序表中所有值为data的元素 
void RemoveAll(PSeqList ps, DataType data);

// 在顺序表中查找值为data的元素,找到返回该元素在顺序表中的位置,否则返回-1 
int SeqListFind(PSeqList ps, DataType data);

// 获取顺序表中元素的个数 
int SeqListSize(PSeqList ps);



////////////////////////////////////////////////// 
//辅助操作 
// 打印顺序表 
void PrintSeqList(PSeqList ps);

// 使用冒泡排序对顺序表中的元素进行排序 
void BubbleSort(PSeqList ps);
void swap(int *po, int *pt);

// 使用选择排序堆顺序表中的元素进行排序 
void SelectSort(PSeqList ps);





# endif //__ORDER_H__

代码

#pragma warning(disable:4996)
# include "order.h"
void test()//测试函数
{
    SeqListInit(&s);//初始化
    SeqListPushBack(&s, 1);//尾插入
    SeqListPushBack(&s, 5);
    SeqListPushBack(&s, 4);
    SeqListPushBack(&s, 3);
    SeqListPushBack(&s, 5);
    SeqListPushBack(&s, 6);
    SeqListPushBack(&s, 6);
    SeqListPopBack(&s);//尾删
    SeqListPushFront(&s, 100);//头插
    SeqListPopFront(&s);//头删
    SeqListInsert(&s, 5, 20);//任意插入
    SeqListErase(&s, 5);//任意删
    //Remove(&s, 5);//删除第一个出现的
    SeqListPushBack(&s, 5);
    SeqListPushBack(&s, 5);
    SeqListPushBack(&s, 6);
    SeqListPushBack(&s, 5);
    RemoveAll(&s, 5);//删除出现的5
    int a = SeqListFind(&s,1);
    SeqListPushBack(&s, 11);
    SeqListPushBack(&s, 13);
    SeqListPushBack(&s, 12);
    PrintSeqList(&s);//打印函数
    SelectSort(&s);//选择排序
    //BubbleSort(&s);//冒泡排序
    PrintSeqList(&s);

}
//顺序表初始化
void SeqListInit(PSeqList ps)
{
    if (NULL == ps)//判断指针是否空
    {
        printf("空指针\n");
        return ;
    }
    ps->_size = 0;
}
// 顺序表的尾插 
void SeqListPushBack(PSeqList ps, DataType data)
{
    if (NULL == ps)
    {
        printf("空指针\n");
        assert(0);
    }
    if (MAX_SIZE == ps->_size)//判断数组是否满
    {
        printf("空间已满,无法写入\n");
        return;
    }
    ps->_array[ps->_size] = data;//尾部插入
    ps->_size++;//长度加一
}

// 顺序表的尾删 
void SeqListPopBack(PSeqList ps)
{
    if (NULL == ps)
    {
        printf("空指针\n");
        assert(0);
    }
    ps->_size--;//长度减一,后面的内容丢弃
}

// 顺序表的头插 
void SeqListPushFront(PSeqList ps, DataType data)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        assert(0);
    }
    if (MAX_SIZE == ps->_size)
    {
        printf("空间已满,无法写入\n");
        return;
    }
    for (i = ps->_size; i > 0; --i)//往后挪,挪出第一个用来装入数据
    {
        ps->_array[i] = ps->_array[i - 1];
    }
    ps->_array[0] = data;
    ps->_size++;
}

// 顺序表的头删 
void SeqListPopFront(PSeqList ps)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        assert(0);
    }
    if (MAX_SIZE == ps->_size)
    {
        printf("空间已满,无法写入\n");
        return;
    }
    for (i = 0; i < ps->_size - 1; ++i)//直接往前挪覆盖
    {
        ps->_array[i] = ps->_array[i + 1];
    }
    ps->_size--;
}

// 顺序表pos位置插入元素data 
void SeqListInsert(PSeqList ps, int pos, DataType data)
{
    int i = 0;
    if (NULL == ps || pos < 0 || pos > ps->_size)
    {
        printf("指针或插入位置有误\n");
        assert(0);
    }
    if (MAX_SIZE == ps->_size)
    {
        printf("空间已满,无法写入\n");
        return;
    }
    for (i =ps->_size ; i >pos ; i --)
    {
        ps->_array[i] = ps->_array[i-1];
    }
    ps->_array[pos] = data;
    ps->_size++;
}

// 删除顺序表pos位置元素 
void SeqListErase(PSeqList ps, int pos)
{
    int i = 0;
    if (NULL == ps ||pos < 0 || pos > ps->_size)//位置必须在_size范围内
    {
        printf("指针或插入位置有误\n");
        return ;
    }
    for (i = pos; i < ps->_size; i++)//挪挪挪
    {
        ps->_array[i] = ps->_array[i + 1];
    }
    ps->_size--;
}

// 移除顺序表中第一个值为data的元素 
void Remove(PSeqList ps, DataType data)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return ;
    }
    for (i = 0; i < ps->_size; i++)//挨个遍历
    {
        if (data == ps->_array[i])
        {
            int j = 0;
            for (j = i; j < ps->_size ; j++)
            {
                ps->_array[j] = ps->_array[j + 1];
            }
            ps->_size--;
            return;
        }
    }

}

// 移除顺序表中所有值为data的元素 
void RemoveAll(PSeqList ps, DataType data)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return;
    }
    //++++++++++++++++++++++++++++++++++
    //1.0
    /*
    for (i = 0; i < ps->_size; i++)
    {
        if (data == ps->_array[i])
        {
            int j = 0;
            for (j = i; j < ps->_size; j++)
            {
                ps->_array[j] = ps->_array[j + 1];
            }
            ps->_size--;
            i--;//i回退一次,就不会跳过当前元素了,因为挪上来的元素有可能也是要找的
        }
    }
    //++++++++++++++++++++++++++++++++++++
    */
    //++++++++++++++++++++++++++++++++++++
    //2.0
    /*
    int temp[MAX_SIZE] = { 0 };
    int count = 0;
    for (i = 0; i < ps->_size; i++)
    {
        if (data == ps->_array[i])
        {
            count++;
        }
        else
        {
            temp[i - count] = ps->_array[i];
        }
    }
    memcpy(ps->_array,temp,sizeof(ps->_array));
    ps->_size -= count;
    //++++++++++++++++++++++++++++++++++++++++
    */
    //++++++++++++++++++++++++++++++++++++++++
    //3.0,时间复杂度O(1)
    int count = 0;
    for (i = 0; i < ps->_size; i++)
    {
        if (data == ps->_array[i])
        {
            count++;
        }
        else
        {
            ps->_array[i - count] = ps->_array[i];
        }
    }
    ps->_size -= count;
}

// 在顺序表中查找值为data的元素,找到返回该元素在顺序表中的位置,否则返回-1 
int SeqListFind(PSeqList ps, DataType data)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return -1;
    }
    for (i = 0; i < ps->_size; i++)
    {
        if (data == ps->_array[i])
        {
            return i;
        }
    }
    return -1;
}

// 获取顺序表中元素的个数 
int SeqListSize(PSeqList ps)
{
    if (NULL == ps)
    {
        printf("空指针\n");
        return -1;
    }
    return ps->_size;
}



// 
//辅助操作 
// 打印顺序表 
void PrintSeqList(PSeqList ps)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return;
    }
    printf("当前元素个数为:%d\n", ps->_size);
    for (i = 0; i < ps->_size; i++)
    {
        printf("%d  ", ps->_array[i]);
    }
    printf("\n");
}

void swap(int *po, int *pt)
{
    /*
    int tmp = po;//这个之所以不行,因为这样交换的是指针地址,里面的内容并没有交换
    po = pt;
    pt = tmp;
    */
    int tmp = *po;
    *po = *pt;
    *pt = tmp;
}
// 使用冒泡排序对顺序表中的元素进行排序 
void BubbleSort(PSeqList ps)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return;
    }
    for (i = 0; i < ps->_size; i++)
    {
        int flog = 0;
        int j = 0;
        for (j = 0; j < ps->_size - i - 1; j++)
        {

            if (ps->_array[j] > ps->_array[j + 1])
            {
                flog = 1;
                swap(&ps->_array[j], &ps->_array[j + 1]);
            }
        }
        if (0 == flog)
        {
            return;
        }
    }
}

// 使用选择排序堆顺序表中的元素进行排序 
void SelectSort(PSeqList ps)
{
    int i = 0;
    if (NULL == ps)
    {
        printf("空指针\n");
        return;
    }
    for (i = 0; i < ps->_size; i ++)
    {
        int flog = 0;
        int j = 0;
        for (j = 0; j < ps->_size -i -1; j++)
        {

            if (ps->_array[j] > ps->_array[j + 1])
            {
                flog = j;
            }
            else
            {
                flog = j + 1;
            }
        }
        swap(&ps->_array[ps->_size - i - 1], &ps->_array[flog]);
    }
}

源文件已上传github,点我跳转

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值