亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2014年07月19日 10:20:54   投稿:shichen2014  
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)順序表基本操作匯總,對(duì)學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的朋友有一定的借鑒價(jià)值,需要的朋友可以參考下

本文匯總了C語(yǔ)言下實(shí)現(xiàn)及操作順序表的方法,對(duì)于學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的朋友來(lái)說(shuō)是一個(gè)不錯(cuò)的參考程序。完整代碼如下:

#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è)線(xiàn)性表
{
 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ǔ)言中的const和free用法詳解

    C語(yǔ)言中的const和free用法詳解

    C語(yǔ)言中的const和C++中的const是有區(qū)別的,而且在使用VS編譯測(cè)試的時(shí)候,如果是C的話(huà),請(qǐng)一定要建立一個(gè)后綴為C的文件,不要是CPP的文件。因?yàn)?,兩個(gè)編譯器會(huì)有差別的。下面通過(guò)本文給大家分享C語(yǔ)言中的const和free用法,感興趣的朋友一起看看吧
    2017-04-04
  • C++中g(shù)SOAP的使用詳解

    C++中g(shù)SOAP的使用詳解

    這篇文章主要介紹了C++中g(shù)SOAP的使用詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-11-11
  • __stdcall 和 __cdecl 的區(qū)別淺析

    __stdcall 和 __cdecl 的區(qū)別淺析

    __stdcall 和 __cdecl 的區(qū)別淺析,需要的朋友可以參考一下
    2013-03-03
  • C++ 私有析構(gòu)函數(shù)的作用示例詳解

    C++ 私有析構(gòu)函數(shù)的作用示例詳解

    這篇文章主要介紹了C++ 私有析構(gòu)函數(shù)的作用,私有析構(gòu)函數(shù)不會(huì)影響棧上對(duì)象的自動(dòng)析構(gòu),它們會(huì)在其作用域結(jié)束時(shí)自動(dòng)調(diào)用析構(gòu)函數(shù)。私有析構(gòu)函數(shù)主要影響的是對(duì)堆上對(duì)象的顯式刪除操作,需要的朋友可以參考下
    2023-06-06
  • Effective?C++?學(xué)習(xí)筆記

    Effective?C++?學(xué)習(xí)筆記

    這篇文章主要介紹了Effective?C++?學(xué)習(xí)筆記,想學(xué)習(xí)Effective?C++的朋友可以參考一下
    2023-08-08
  • C語(yǔ)言超全面覆蓋操作符知識(shí)點(diǎn)

    C語(yǔ)言超全面覆蓋操作符知識(shí)點(diǎn)

    C?語(yǔ)言提供了豐富的操作符,有:算術(shù)操作符,移位操作符,位操作符,賦值操作符,單目操作符,關(guān)系操作符,邏輯操作符,條件操作符等。讓我們通讀本篇來(lái)詳細(xì)了解吧
    2022-06-06
  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列

    這篇文章主要介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)遞歸之斐波那契數(shù)列的相關(guān)資料,希望通過(guò)本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • Opencv開(kāi)發(fā)實(shí)現(xiàn)拼圖游戲

    Opencv開(kāi)發(fā)實(shí)現(xiàn)拼圖游戲

    這篇文章主要為大家詳細(xì)介紹了Opencv開(kāi)發(fā)實(shí)現(xiàn)拼圖游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C語(yǔ)言中棧的結(jié)構(gòu)和函數(shù)接口的使用示例

    C語(yǔ)言中棧的結(jié)構(gòu)和函數(shù)接口的使用示例

    這篇文章主要介紹了C語(yǔ)言中棧的結(jié)構(gòu)和函數(shù)接口的使用,類(lèi)似很多軟件都有撤銷(xiāo)的操作,這其實(shí)就是用棧這種方法來(lái)實(shí)現(xiàn)的,當(dāng)然不同的軟件具體實(shí)現(xiàn)代碼會(huì)有差異,不過(guò)原理大多都是一樣的
    2023-02-02
  • C++異常處理入門(mén)(try和catch)

    C++異常處理入門(mén)(try和catch)

    C++ 提供了異常機(jī)制,讓我們能夠捕獲運(yùn)行時(shí)錯(cuò)誤,本文就詳細(xì)的介紹了C++異常處理入門(mén),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08

最新評(píng)論