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 10
typedef 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("已按升序排列\(zhòng)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;
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市刚夺,隨后出現(xiàn)的幾起案子砂豌,更是在濱河造成了極大的恐慌,老刑警劉巖光督,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阳距,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡结借,警方通過(guò)查閱死者的電腦和手機(jī)筐摘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)船老,“玉大人咖熟,你說(shuō)我怎么就攤上這事×希” “怎么了馍管?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)薪韩。 經(jīng)常有香客問(wèn)我确沸,道長(zhǎng),這世上最難降的妖魔是什么俘陷? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任罗捎,我火速辦了婚禮,結(jié)果婚禮上拉盾,老公的妹妹穿的比我還像新娘桨菜。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開(kāi)白布倒得。 她就那樣靜靜地躺著泻红,像睡著了一般。 火紅的嫁衣襯著肌膚如雪霞掺。 梳的紋絲不亂的頭發(fā)上谊路,一...
    開(kāi)封第一講書(shū)人閱讀 49,046評(píng)論 1 285
  • 那天,我揣著相機(jī)與錄音根悼,去河邊找鬼。 笑死蜀撑,一個(gè)胖子當(dāng)著我的面吹牛挤巡,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播酷麦,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼矿卑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了沃饶?” 一聲冷哼從身側(cè)響起母廷,我...
    開(kāi)封第一講書(shū)人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎糊肤,沒(méi)想到半個(gè)月后琴昆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡馆揉,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年业舍,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片升酣。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡舷暮,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出噩茄,到底是詐尸還是另有隱情下面,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布绩聘,位于F島的核電站沥割,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏凿菩。R本人自食惡果不足惜驯遇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蓄髓。 院中可真熱鬧叉庐,春花似錦、人聲如沸会喝。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至枉阵,卻和暖如春译红,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背兴溜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工侦厚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人拙徽。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓刨沦,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親膘怕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子想诅,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容