欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++實現(xiàn)線性表順序存儲的示例代碼

 更新時間:2023年03月02日 09:03:03   作者:NDX  
這篇文章主要為大家詳細介紹了C++實現(xiàn)線性表順序存儲的相關知識,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的可以了解一下

我學習順序表時找不到相關的代碼,以及我不清楚寫一個線性表需要的知識,當我寫出來可以使用的線性表我就把這些內容貼了出來。

前置知識點:結構體,常量指針

順序表的特點:

  • 需要一片連續(xù)的存儲空間
  •  邏輯上相連的數(shù)據(jù)的存儲位置也是相鄰的。

所以如果我們想要創(chuàng)建一個順序表我們需要做兩件事:

  • 向系統(tǒng)申請一片空間供數(shù)組使用。
  • 創(chuàng)建一個指針記錄空間地址。

而刪除順序表就是把空間釋放,并讓指針指向空。

順序表的創(chuàng)建和銷毀:

#include<iostream>
#include<cstdlib>
#define EleType int//方便日后使用
#define Maxsize 1000
using namespace std;

//定義結構體
struct sql{
    int* elem;
    int len;//防止越界訪問
};


//初始化
void InitList(sql &l)
{
    l.elem=new int [Maxsize];
    if(!l.elem) cout<<"申請空間失敗"<<endl;
    l.len=0;
}

//銷毀線性表
void DestroyList(sql &l)
{
    delete [] l.elem;
    l.elem=nullptr;
}

int main()
{
    sql l;
    InitList(l);
    return 0;

}

數(shù)據(jù)的插入和刪除:

因為在順序存儲所有的數(shù)據(jù)的存儲地址是連續(xù)的,所以在插入和刪除數(shù)據(jù)時你需要改變后續(xù)的所有數(shù)據(jù)的位置。在插入時把后面的數(shù)據(jù)往后挪,刪除時把數(shù)據(jù)向前挪。

void adds(sql &l,EleType target,int sit)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;//插入位置錯誤
        exit(0);
    }
    if(l.len+1>Maxsize)
    {
        cout<<"Too many"<<endl;//存儲空間已滿
        exit(0);
    }
    //把后面的數(shù)據(jù)往后挪
    for(int i=l.len-1;i>=sit-1;i--)
    {
        l.elem[i+1]=l.elem[i];
    }
    l.elem[sit-1]=target;
    l.len++;//更新表長
}

//刪除元素
void DeletElem(sql &l,int sit)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;
        exit(0);
    }
    for(int i=sit-1;i<l.len;i++)
    {
        l.elem[i]=l.elem[i+1];
    }
    l.len--;//更新表長
}

其他操作:

查找和更改:

//查找
int finding(sql l,EleType target)
{
    for(int i=0;i<l.len;i++)
    {
        if(l.elem[i]==target) return i+1;
    }
    return 0;
}

//更改
void Changing(sql& l,int sit,EleType target)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;
        exit(0);
    }
    l.elem[sit-1]=target;
}

清空、獲取長度、判斷是否為空:

//清空線性表
void ClearLine(sql &l)
{
    l.len=0;
}

//獲取線性表的長度
int Getlen(sql l)
{
    return l.len;
}

//判斷線性表是否為空
bool IsEmpty(sql l)
{
    if(l.len==0) return true;
    return false;
}

完整代碼

#include<iostream>
#include<cstdlib>
#define Maxsize 1000
#define EleType int//方便日后使用
using namespace std;

//創(chuàng)建結構體
struct sql{
    EleType* elem;//創(chuàng)建一個指針
    int len;
};

//初始化
void InitList(sql &l)
{
   
    l.elem=new EleType [Maxsize];
    if(!l.elem) cout<<"申請空間失敗"<<endl;
    l.len=0;
}


//輸出
void print(sql l)
{
    for(int i=0;i<l.len;i++)
    {
        cout<<l.elem[i]<<" ";
    }
    cout<<endl;
}

//插入
void adds(sql &l,EleType target,int sit)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;
        exit(0);
    }
    if(l.len+1>Maxsize)
    {
        cout<<"Too many"<<endl;
        exit(0);
    }
    for(int i=l.len-1;i>=sit-1;i--)
    {
        l.elem[i+1]=l.elem[i];
    }
    l.elem[sit-1]=target;
    l.len++;
}

//刪除元素
void DeletElem(sql &l,int sit)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;
        exit(0);
    }
    for(int i=sit-1;i<l.len;i++)
    {
        l.elem[i]=l.elem[i+1];
    }
    l.len--;
}

//銷毀線性表
void DestroyList(sql &l)
{
    delete [] l.elem;
}

//清空線性表
void ClearLine(sql &l)
{
    l.len=0;
}

//獲取線性表的長度
int Getlen(sql l)
{
    return l.len;
}

//判斷線性表是否為空
bool IsEmpty(sql l)
{
    if(l.len==0) return true;
    return false;
}

//查找
int finding(sql l,EleType target)
{
    for(int i=0;i<l.len;i++)
    {
        if(l.elem[i]==target) return i+1;
    }
    return 0;
}

//更改
void Changing(sql& l,int sit,EleType target)
{
    if(sit>l.len+1 || sit <1)
    {
        cout<<"sit is wrong"<<endl;
        exit(0);
    }
    l.elem[sit-1]=target;
}

int main()
{
    sql l;
    InitList(l);
    EleType j=0;
    for(int i=1;i<10;i++,j++)
        adds(l,j,i);
    DeletElem(l,2);
    print(l);
    return 0;

}

到此這篇關于C++實現(xiàn)線性表順序存儲的示例代碼的文章就介紹到這了,更多相關C++線性表順序存儲內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 基于linux下C開發(fā)中的幾點技術經驗總結

    基于linux下C開發(fā)中的幾點技術經驗總結

    本篇文章是對linux下C開發(fā)中的幾點技術經驗總結進行了詳細的分析介紹,需要的朋友參考下
    2013-05-05
  • 帶你粗略了解c++的最大乘積

    帶你粗略了解c++的最大乘積

    這篇文章主要為大家詳細介紹了C++的最大乘積,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能給你帶來幫助
    2021-08-08
  • C++中的常對象與常對象成員詳解

    C++中的常對象與常對象成員詳解

    常成員函數(shù)可以訪問常對象中的數(shù)據(jù)成員,但仍然不允許修改常對象中數(shù)據(jù)成員的值。有時在編程時有要求,一定要修改常對象成員中的某個數(shù)據(jù)成員的值(例如類中有一個用于計數(shù)的變量count,其值應當不能變化)
    2013-10-10
  • 使用C++繪制GDI位圖的基本編寫實例

    使用C++繪制GDI位圖的基本編寫實例

    這篇文章主要介紹了使用C++繪制GDI位圖的基本編寫實例,一般來說適用于Windwos下的C++的GUI編程,需要的朋友可以參考下
    2015-12-12
  • VScode配置C++運行環(huán)境的完整步驟

    VScode配置C++運行環(huán)境的完整步驟

    這篇文章主要給大家介紹了關于VScode配置C++運行環(huán)境的完整步驟,文中通過圖文介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • 推箱子游戲C語言實現(xiàn)代碼

    推箱子游戲C語言實現(xiàn)代碼

    這篇文章主要為大家詳細介紹了推箱子游戲C語言實現(xiàn)代碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C/C++ 常用排序算法整理匯總分享

    C/C++ 常用排序算法整理匯總分享

    排序算法,就是如何使得記錄按照要求排列的方法。排序算法在很多領域得到相當?shù)刂匾?,尤其是在大量?shù)據(jù)的處理方面。一個優(yōu)秀的算法可以節(jié)省大量的資源。本篇整理了c語言和c++的常用的排序算法,感興趣的朋友可以參考下
    2021-06-06
  • c++多線程為何要使用條件變量詳解

    c++多線程為何要使用條件變量詳解

    多線程是多任務處理的一種特殊形式,下面這篇文章主要給大家介紹了關于c++多線程為何要使用條件變量的相關資料,需要的朋友可以參考下
    2021-06-06
  • Qt利用QGraphicsView繪制跳舞的機器人

    Qt利用QGraphicsView繪制跳舞的機器人

    最近新學了一招秘密武器,打算分享給大家!那就是如何在QGraphicsView中制作一個跳舞的機器人,快跟隨小編一起動手嘗試一下吧
    2022-06-06
  • C語言詳細講解循環(huán)語句的妙用

    C語言詳細講解循環(huán)語句的妙用

    C語言循環(huán)控制語句是一個基于C語言的編程語句,該語句主要有while循環(huán)語句、do-while循環(huán)語句和for循環(huán)語句來實現(xiàn)循環(huán)結構,在循環(huán)過程中還有關鍵字break、continue、do、break控制中斷繼續(xù)與結束等操作
    2022-04-04

最新評論