鱼C论坛

 找回密码
 立即注册
查看: 2579|回复: 0

[学习笔记] 数据结构与算法—线性表的顺序存储结构C++实现

[复制链接]
发表于 2017-7-23 17:15:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x

// 小甲鱼 的 数据结构与算法
//  线性表的 顺序存储结构  C++ 实现


#include <iostream>


const int MAXSIZE = 30;
typedef int Elemtype;

//创建链表结构
struct sqlist
{
        Elemtype sdata[MAXSIZE];
        int length ;
};

//初始化
void list_init(sqlist *s)
{
        s->length = 0;
        s->sdata[s->length] = 0;
}

//从尾部插入元素
void stern_insert(sqlist *s,Elemtype e)
{
        s->sdata[s->length] = e;
        s->length++;
        s->sdata[s->length] = '\0';
}


//从头部插入元素
void head_insert(sqlist *s, Elemtype e)
{
        for (int i = s->length; i > 0; --i)
        {
                s->sdata[i] = s->sdata[i - 1];
        }
        s->sdata[0] = e;
        s->length++;
        s->sdata[s->length] = '\0';
}

//从任意位置插入元素
void optional_insert(sqlist *s, Elemtype e, int x)
{
        if (x <= s->length)  //判断X是否大于length
        {
                for (int i = s->length; i > x; i--)  // 依次将数据后移一位
                {
                        s->sdata[i] = s->sdata[i - 1];
                }
                s->sdata[x] = e;   // 在指定位置插入 数据
                s->length++;       // 数据长度加1
                s->sdata[s->length] = '\0';
        }
       
}

//删除元素
int  optional_delete(sqlist *s, Elemtype e)
{
        if (s->length ==0)
        {
                return -1; // 链表中没有元素
        }
        int x = 0;
        //遍历整个结构,找到要删除的数据的位置 返回给x
        for (int i = 0; i< s->length;i++)  
        {
                if (s->sdata[i] == e)
                {
                        x = i;
                        break;
                }
                else
                {
                        return -1;  // 链表中没有你要删除的元素
                }
        }
        for (int i = x; i < s->length; i++)
        {
                s->sdata[i] = s->sdata[i + 1];
        }
        s->length--;
        s->sdata[s->length] = '\0';
        return 0;
}

int main()
{
        sqlist s;
        list_init(&s);
        stern_insert(&s, 3);
        stern_insert(&s, 4);
        stern_insert(&s, 5);
        head_insert(&s, 2);
        head_insert(&s, 1);
        optional_insert(&s, 6, 5);
        optional_delete(&s, 2);


       

        return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-24 13:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表