麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > C > 正文

匯總C語(yǔ)言實(shí)現(xiàn)順序表的基本操作

2020-02-24 14:29:08
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

序列表及其基本操作實(shí)現(xiàn)NN序列表是最簡(jiǎn)單的數(shù)據(jù)結(jié)構(gòu)之一,在計(jì)算機(jī)中,序列表通常以數(shù)組的形式保存,我們都知道數(shù)組是線性的,今天就讓武林技術(shù)頻道小編匯總C語(yǔ)言實(shí)現(xiàn)順序表的基本操作吧!

完整代碼如下:

#include<stdio.h>#include<stdlib.h>#define TRUE  1#define FALSE 0#define OK   1#define ERROR 0#define OVERFLOW -2#define LIST_INIT_SIZE 100#define LISTINCREMENT 10typedef int status ;typedef int ElemType ;typedef struct{ ElemType *elem; int length,listsize;}SqList;status InitList(SqList &L)//初始化{ L.elem=(ElemType *)malloc(LIST_INIT_SIZE*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize=LIST_INIT_SIZE; L.length=0; return OK;}status Build(SqList &L)//建立表{ int i,n; printf("請(qǐng)輸入元素個(gè)數(shù)n和n個(gè)元素/n"); scanf("%d",&n); if(n>LIST_INIT_SIZE)//如果n大于當(dāng)前空間 { L.elem=(ElemType *)realloc(L.elem,(n+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize=n+LISTINCREMENT; } for(i=0;i<n;i++) scanf("%d",L.elem+i); L.length=n; return OK;}void Print(SqList &L)//輸出表中元素和長(zhǎng)度{ int i; for(i=0;i<L.length;i++) printf("%d ",*(L.elem+i)); printf("/n長(zhǎng)度為:%d/n/n",L.length);}void Tips()//提示函數(shù){ printf("請(qǐng)選擇你的想要的操作:/n"); printf("<1> 輸出順序表及順序表的長(zhǎng)度/n"); printf("<2> 刪除值為x的結(jié)點(diǎn)/n"); printf("<3> 刪除給定位置i的結(jié)點(diǎn)/n"); printf("<4> 將順序表逆置/n"); printf("<5> 將順序表按升序排序/n"); printf("<6> 將x插入到順序表的適當(dāng)位置上/n"); printf("<7> 將兩個(gè)有序表合并/n"); printf("<0> 退出/n/n");}status ListDelete1(SqList &L,int x)//刪除值為X的元素{ int i; for(i=0;i<L.length;i++) if(*(L.elem+i)==x)  break; if(i==L.length) return ERROR; for(i++;i<L.length;i++) *(L.elem+i-1)=*(L.elem+i); L.length--; return OK;}status ListDelete2(SqList &L,int x)//刪除第X個(gè)元素{ int i; if(x<0||x>=L.length) return ERROR; for(i=x+1;i<L.length;i++) *(L.elem+i-1)=*(L.elem+i); L.length--; return OK;}void Inverse(SqList &L)//逆置函數(shù){ int i,t; for(i=0;i<L.length/2;i++) { t=*(L.elem+i); *(L.elem+i)=*(L.elem+L.length-i-1); *(L.elem+L.length-i-1)=t; }}void Sort(SqList &L)//冒泡排序(升序){ int i,j,t; for(i=1;i<L.length;i++) for(j=0;j<L.length-i;j++) {  if(*(L.elem+j)>*(L.elem+j+1))  {   t=*(L.elem+j);   *(L.elem+j)=*(L.elem+j+1);   *(L.elem+j+1)=t;  } } printf("已按升序排列/n/n");}status ListInsert(SqList &L,int x)//將X插入,使仍然有序{ int i,k; if(L.length>=L.listsize) { L.elem=(ElemType *)realloc(L.elem,(L.listsize+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); L.listsize+=LISTINCREMENT; } for(i=0;i<L.length;i++) if(x<*(L.elem+i))  break; k=i; for(i=L.length;i>k;i--) *(L.elem+i)=*(L.elem+i-1); *(L.elem+k)=x; L.length++; return OK;}status Merger(SqList &L,SqList &Lb)//合并兩個(gè)線性表{ int i,j,k; SqList Lc; InitList(Lc); if(Lc.listsize<L.length+Lb.length) { Lc.elem=(ElemType *)realloc(Lc.elem,(L.length+Lb.length+LISTINCREMENT)*sizeof(ElemType)); if(!L.elem) exit(OVERFLOW); Lc.listsize=L.length+Lb.length+LISTINCREMENT; } i=j=k=0; while(i<L.length && j<Lb.length) { if(*(L.elem+i) < *(Lb.elem+j)) {  *(Lc.elem+k)=*(L.elem+i);  k++;i++; } else {  *(Lc.elem+k)=*(Lb.elem+j);  k++;j++; } } while(i<L.length) { *(Lc.elem+k)=*(L.elem+i); k++;i++; } while(j<Lb.length) { *(Lc.elem+k)=*(Lb.elem+j); k++;j++; } Lc.length=L.length+Lb.length; L=Lc; return OK;}int main(){ int op,x,flag; SqList L,Lb; InitList(L); Build(L); Tips(); scanf("%d",&op); while(op) { switch(op) { case 1:  Print(L);  break; case 2:  printf("請(qǐng)輸入要?jiǎng)h除的數(shù)據(jù)X:/n");  scanf("%d",&x);  flag=ListDelete1(L,x);  if(flag)  printf("刪除成功!!/n/n");  else  printf("元素不存在,刪除失敗!!/n/n");  break; case 3:  printf("請(qǐng)輸入要?jiǎng)h除的位置i:/n");  scanf("%d",&x);  flag=ListDelete2(L,x-1);//第i個(gè)元素對(duì)應(yīng)的下標(biāo)為i-1  if(flag)  printf("刪除成功!!/n/n");  else  printf("元素不存在,刪除失敗!!/n/n");  break; case 4:  Inverse(L);  break; case 5:  Sort(L);  break; case 6:  printf("請(qǐng)輸入要插入的數(shù)據(jù)X:/n");  scanf("%d",&x);  flag=ListInsert(L,x);     if(flag)  printf("插入成功!!/n/n");  else  printf("插入失敗!!/n/n");  break; case 7:  printf("請(qǐng)輸入Lb的內(nèi)容:/n");  InitList(Lb);  Build(Lb);  flag=Merger(L,Lb);  if(flag)  printf("合并成功!!/n/n");  break; }  Tips();  scanf("%d",&op); } return 0;}

?以上就是關(guān)于匯總C語(yǔ)言實(shí)現(xiàn)順序表的基本操作,其實(shí)大家是可以選擇到可靠的平臺(tái)進(jìn)行學(xué)習(xí)的,推薦武林技術(shù)頻道網(wǎng)給大家學(xué)習(xí)專業(yè)的程序知識(shí)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 美女喷水网站 | 亚洲性爰 | 免费欧美一级视频 | 久久色伦理资源站 | 久久91精品国产91久久yfo | 久久国产在线观看 | 久久成人精品视频 | 国产免费永久在线观看 | 黄色大片在线观看 | 一级一片免费 | 51国产偷自视频区视频小蝌蚪 | 国产女厕一区二区三区在线视 | 成人免费一区二区三区在线观看 | 一级毛片在线观看免费 | 久草在线视频中文 | 亚洲一区二区三区高清 | 国产噜噜噜 | 羞羞网站在线看 | 日日草夜夜操 | 久草在线高清 | 黄视频免费在线 | 精品一区二区三区中文字幕 | 国产人成精品一区二区三 | 精品国产视频一区二区三区 | 久草在线资源观看 | 免费高潮在线国 | 精品一区二区三区中文字幕老牛 | 国产亚洲精品久久久久久久久 | 日日爱夜夜操 | 精品免费国产一区二区三区 | 中文字幕一区2区 | 久久影院在线观看 | 欧美一级黄色免费看 | 91网站链接 | 欧美日韩亚州综合 | 欧美激情综合网 | 制服丝袜成人动漫 | 久章草影院 | 久久精品一级 | 国产视频软件在线 | 毛片在线免费视频 |