數(shù)據(jù)結(jié)構(gòu)順序表操作示例
#include<stdio.h>
#include<malloc.h>
#define maxsize 1024
typedef char datatype;
typedef struct
{
datatype data[maxsize];
int last;
}sequenlist;
/*在第I個(gè)元素前插入數(shù)據(jù)x,元素從0開始計(jì)數(shù)*/
int insert(sequenlist *L,datatype x,int i)
{
int j;
if(L->last==maxsize-1)
{
printf("overflow");
return 0;
}
else if((i<0)||(i>L->last))
{
printf("error,please input the right 'i'");
return 0;
}
else
{
for(j=L->last;j>=i;j--)
{
L->data[j+1]=L->data[j];
L->data[i]=x;
L->last=L->last +1;
}
}
return(1);
}
/*刪除第i個(gè)元素,元素從0開始計(jì)數(shù)*/
int dellist(sequenlist *L,int i)
{
if((i<0)||(i>L->last))
{printf("error,please input the right 'i'");
return 0;}
else
{
for(;i<L->last ;i++)
L->data[i]=L->data[i+1];
L->last =L->last-1;
return(1);
}
}
/*建立順序表,其元素為單個(gè)字符*/
void createlist(sequenlist *L)
{
int n,i;
char tmp;
printf("請(qǐng)輸入元素個(gè)數(shù):\n");
scanf("%d",&n);
for(i=0;i<n;i++)
{
printf("data[%d]=",i);
fflush(stdin);
scanf("%c",&tmp);
L->data[i] =tmp;
}
L->last=n-1;
printf("/n");
}
/*打印順序表*/
void printflist(sequenlist *L)
{
int i;
for(i=0;i<L->last ;i++)
{
printf("data[%d]=",i);
printf("%c\n",L->data [i]);
}
}
main()
{
sequenlist *L;
char cmd,x;
int i;
L=(sequenlist *)malloc(sizeof(sequenlist)); /*指針在使用前初始化*/
createlist(L);
printflist(L);
do
{
printf("i,I...插入\n");
printf("d,D...刪除\n");
printf("q,Q...退出\n");
do
{
fflush(stdin);
scanf("%c",&cmd);
}while((cmd!='d')&&(cmd!='D')&&(cmd!='q')&&(cmd!='Q')&&(cmd!='i')&&(cmd!='I'));
switch(cmd)
{
case 'i':
case 'I':
printf("請(qǐng)輸入你要插入的數(shù)據(jù):");
fflush(stdin);
scanf("%c",&x);
printf("請(qǐng)輸入你要插入的位置:");
scanf("%d",&i);
insert(L,x,i);
printflist(L);
break;
case 'd':
case 'D':
printf("請(qǐng)輸入你要?jiǎng)h除的元素的位置:");
fflush(stdin);
scanf("%d",&i);
dellist(L,i);
printflist(L);
break;
}
}while((cmd!='q')&&(cmd!='Q'));
}
- python實(shí)現(xiàn)bitmap數(shù)據(jù)結(jié)構(gòu)詳解
- java數(shù)據(jù)結(jié)構(gòu)和算法學(xué)習(xí)之漢諾塔示例
- LinkedList學(xué)習(xí)示例模擬堆棧與隊(duì)列數(shù)據(jù)結(jié)構(gòu)
- C數(shù)據(jù)結(jié)構(gòu)之雙鏈表詳細(xì)示例分析
- C數(shù)據(jù)結(jié)構(gòu)之單鏈表詳細(xì)示例分析
- 從數(shù)據(jù)結(jié)構(gòu)的角度分析 for each in 比 for in 快的多
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車次數(shù)的問題詳解
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-用棧實(shí)現(xiàn)表達(dá)式求值的方法詳解
- 解析從源碼分析常見的基于Array的數(shù)據(jù)結(jié)構(gòu)動(dòng)態(tài)擴(kuò)容機(jī)制的詳解
- C++ 冒泡排序數(shù)據(jù)結(jié)構(gòu)、算法及改進(jìn)算法
- 從數(shù)據(jù)結(jié)構(gòu)分析看:用for each...in 比 for...in 要快些
- C#數(shù)據(jù)結(jié)構(gòu)之循環(huán)鏈表的實(shí)例代碼
- Oracle 11g Release (11.1) 索引底層的數(shù)據(jù)結(jié)構(gòu)
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘五 棧和隊(duì)列
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘四 雙向鏈表
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘三 鏈表
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘二 線性結(jié)構(gòu)
- C#數(shù)據(jù)結(jié)構(gòu)與算法揭秘一
相關(guān)文章
C++實(shí)現(xiàn)中綴轉(zhuǎn)后綴的示例詳解
這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)中綴轉(zhuǎn)后綴的問題,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09c++ vector對(duì)象相關(guān)總結(jié)
這篇文章主要介紹了c++ vector對(duì)象的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用c++,感興趣的朋友可以了解下2021-02-02C語言實(shí)現(xiàn)簡(jiǎn)單推箱子小游戲
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-11-11C++中回調(diào)函數(shù)(CallBack)的用法分析
這篇文章主要介紹了C++中回調(diào)函數(shù)(CallBack)的用法,較為詳細(xì)的分析了C++中回調(diào)函數(shù)(CallBack)的原理并以實(shí)例形式總結(jié)了其具體用法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01OpenCV實(shí)現(xiàn)圖像輪廓檢測(cè)以及外接矩形
這篇文章主要為大家詳細(xì)介紹了OpenCV實(shí)現(xiàn)圖像輪廓檢測(cè)以及外接矩形,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01對(duì)for循環(huán)中表達(dá)式和循環(huán)體的執(zhí)行順序詳解
今天小編就為大家分享一篇對(duì)for循環(huán)中表達(dá)式和循環(huán)體的執(zhí)行順序詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-06-06Qt學(xué)習(xí)教程之對(duì)話框消失動(dòng)畫效果
這篇文章主要給大家介紹了關(guān)于Qt學(xué)習(xí)教程之對(duì)話框消失動(dòng)畫效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07