一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - 詳解C語言之順序表

詳解C語言之順序表

2022-02-24 14:48ぃ咔哇依°ヽ C/C++

這篇文章主要為大家介紹了C語言的順序表,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助

一、思維導圖

詳解C語言之順序表

二、步驟

1.初始化

代碼如下:

?
1
2
3
4
void ListInit(SeqList *L)
{
    L->size = 0;
}

2.求表長

代碼如下:

?
1
2
3
4
int ListLength(SeqList L)
{
    return L.size;
}

3.插入數據元素

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int ListInsert(SeqList *L, int i, DataType x)
{
    int j;
    if (L->size >= MaxSize)
    {
        printf("順序表已滿,插入失?。。?!\n");
        return 0;
    }
    else if (i<0 || i>L->size)
    {
        printf("參數i不合法,插入失?。。?!\n");
        return 0;
    }
    else
    {
        for (j = L->size; j > i; j--)
            L->list[j] = L->list[j - 1];
        L->list[i] = x;
        L->size++;
        return 1;
    }
}

4.刪除數據元素

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
int ListInsert(SeqList *L, int i, DataType x)
{
    int j;
    if (L->size >= MaxSize)
    {
        printf("順序表已滿,插入失?。。。n");
        return 0;
    }
    else if (i<0 || i>L->size)
    {
        printf("參數i不合法,插入失?。。。n");
        return 0;
    }
    else
    {
        for (j = L->size; j > i; j--)
            L->list[j] = L->list[j - 1];
        L->list[i] = x;
        L->size++;
        return 1;
    }
}

5.取出數據元素

按位查找

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
int ListGet(SeqList L, int i, DataType *x)
{
    if (L.size <= 0)
    {
        printf("順序表已空,取出元素失?。。?!\n");
        return 0;
    }
    else if (i < 0 || i >= L.size)
    {
        printf("參數i不合法,取出元素失敗!??!\n");
        return 0;
    }
    else
    {
        *x = L.list[i];
        return 1;
    }
}

按位查找

代碼如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
int ListGetZ(SeqList L, DataType x, int *i)
{
    int j;
    for (j = 0; j < ListLength(L); j++)
    {
        if (L.list[j] == x)
        {
            *i = j;
            return 1;
        }
    }
    return 0;
}

所有代碼

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
#include <stdio.h>
#define MaxSize 1024 //數組能存儲的最大最大元素個數
typedef int DataType; //存儲數據元素的數據類型
typedef struct
{
    DataType list[MaxSize];
    int size; //當前存儲的數據元素個數
}SeqList;
//初始化
void ListInit(SeqList *L)
{
    L->size = 0;
}
//求表長
int ListLength(SeqList L)
{
    return L.size;
}
//插入數據元素
int ListInsert(SeqList *L, int i, DataType x)
{
    int j;
    if (L->size >= MaxSize)
    {
        printf("順序表已滿,插入失敗!??!\n");
        return 0;
    }
    else if (i<0 || i>L->size)
    {
        printf("參數i不合法,插入失敗?。?!\n");
        return 0;
    }
    else
    {
        for (j = L->size; j > i; j--)
            L->list[j] = L->list[j - 1];
        L->list[i] = x;
        L->size++;
        return 1;
    }
}
//刪除數據元素
int ListDelete(SeqList *L, int i, DataType *x)
{
    int j;
    if (L->size <= 0)
    {
        printf("順序表已空,刪除失?。。?!\n");
        return 0;
    }
    else if (i < 0 || i >= L->size)
    {
        printf("參數i不合法,刪除失?。。?!\n");
        return 0;
    }
    else
    {
        *x = L->list[i];
        for (j = i; j < L->size - 1; j++)
            L->list[j] = L->list[j + 1];
        L->size--;
        return 1;
    }
}
//取出數據元素
//按位查找
void ListGet(SeqList L, int i, DataType *x)
{
    if (L.size <= 0)
    {
        printf("順序表已空,取出元素失?。。?!\n");
        return 0;
    }
    else if (i < 0 || i >= L.size)
    {
        printf("參數i不合法,取出元素失?。。。n");
        return 0;
    }
    else
    {
        *x = L.list[i];
        return 1;
    }
}
//安值查找
int ListGetZ(SeqList L, DataType x, int *i)
{
    int j;
    for (j = 0; j < ListLength(L); j++)
    {
        if (L.list[j] == x)
        {
            *i = j;
            return 1;
        }
    }
    return 0;
}
int main()
{
    SeqList L;
    int i, x;
    ListInit(&L);
    for (i = 0; i < 10; i++)
        ListInsert(&L, i, i + 10);
    ListDelete(&L, 4, &x);
    for (i = 0; i < ListLength(L); i++)
    {
        ListGet(L, i, &x);
        printf("%d ", x);
    }
    system("pause");
    return 0;
}

總結

本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關注服務器之家的更多內容!

原文鏈接:https://blog.csdn.net/qq_44887198/article/details/121218324

延伸 · 閱讀

精彩推薦
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
主站蜘蛛池模板: 91欧美国产 | 成人精品一区二区三区中文字幕 | 国产亚洲精品美女久久久 | 国产欧美视频在线观看 | 91原创国产 | 日本妇人成熟免费不卡片 | 我把寡妇日出水好爽 | 日本道色综合久久影院 | 久久re6热在线视频 久久AV喷吹AV高潮欧美 | 插入粉嫩| 日本在线www | a级在线看 | 欧美日本一道高清免费3区 欧美人做人爱a全程免费 | 波多野结在线 | 日本老妇人乱视频 | 91东航翘臀女神在线播放 | 国产经典一区二区三区蜜芽 | 范冰冰好紧好滑好湿 | 国内精品视频一区二区三区八戒 | 日本又黄又裸一级大黄裸片 | 国产亚洲精品看片在线观看 | 亚洲欧美在线观看首页 | 免费观看俄罗斯特黄特色 | 日韩一 | 精品在线网站 | 国产乱码免费卡1卡二卡3卡四 | 77成人影院 | 天天综合网天天做天天受 | 精品久久久久久久久久久久久久久 | 日本小视频网站 | 奇米影视奇米色777欧美 | 91麻豆影视 | 亚洲国产99在线精品一区二区 | 免费欧美一级 | 性夜夜春夜夜爽AA片A | 高h短篇合集 | 亚洲成av人片在线观看天堂无码 | 糖心在线观看 | 日本中文字幕在线视频站 | 99精品国产自在现线观看 | 亚洲精品国产一区二区在线 |