欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

數(shù)據(jù)結構順序表操作示例

 更新時間:2014年03月06日 10:22:15   作者:  
這篇文章主要介紹了數(shù)據(jù)結構順序表操作示例,其中有在第I個元素前插入數(shù)據(jù)x,元素從0開始計數(shù)、刪除第i個元素,元素從0開始計數(shù)的方法,需要的朋友可以參考下

復制代碼 代碼如下:

#include<stdio.h>
#include<malloc.h>
#define maxsize 1024
typedef char datatype;
typedef struct
{
 datatype data[maxsize];
 int last;
}sequenlist;


/*在第I個元素前插入數(shù)據(jù)x,元素從0開始計數(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個元素,元素從0開始計數(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);
  }
}


/*建立順序表,其元素為單個字符*/
void createlist(sequenlist *L)
{
 int n,i;
 char tmp;
 printf("請輸入元素個數(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("請輸入你要插入的數(shù)據(jù):");
   fflush(stdin);
   scanf("%c",&x);
   printf("請輸入你要插入的位置:");
   scanf("%d",&i);
   insert(L,x,i);
   printflist(L);
   break;

  case 'd':
  case 'D':
   printf("請輸入你要刪除的元素的位置:");
   fflush(stdin);
   scanf("%d",&i);
   dellist(L,i);
   printflist(L);
   break;
 }
 }while((cmd!='q')&&(cmd!='Q'));
}

相關文章

  • 基于樹莓派實現(xiàn)播放MP3音樂

    基于樹莓派實現(xiàn)播放MP3音樂

    這篇文章主要為大家詳細介紹了基于樹莓派實現(xiàn)播放MP3音樂,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • OpenCV實現(xiàn)平均背景法

    OpenCV實現(xiàn)平均背景法

    這篇文章主要為大家詳細介紹了OpenCV實現(xiàn)平均背景法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-03-03
  • C++實現(xiàn)中綴轉后綴的示例詳解

    C++實現(xiàn)中綴轉后綴的示例詳解

    這篇文章主要為大家詳細介紹了如何利用C++實現(xiàn)中綴轉后綴的問題,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • C語言實現(xiàn)火車訂票系統(tǒng)

    C語言實現(xiàn)火車訂票系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)火車訂票系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • c++ vector對象相關總結

    c++ vector對象相關總結

    這篇文章主要介紹了c++ vector對象的相關資料,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下
    2021-02-02
  • C語言實現(xiàn)簡單推箱子小游戲

    C語言實現(xiàn)簡單推箱子小游戲

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)推箱子小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • C++中回調函數(shù)(CallBack)的用法分析

    C++中回調函數(shù)(CallBack)的用法分析

    這篇文章主要介紹了C++中回調函數(shù)(CallBack)的用法,較為詳細的分析了C++中回調函數(shù)(CallBack)的原理并以實例形式總結了其具體用法,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • OpenCV實現(xiàn)圖像輪廓檢測以及外接矩形

    OpenCV實現(xiàn)圖像輪廓檢測以及外接矩形

    這篇文章主要為大家詳細介紹了OpenCV實現(xiàn)圖像輪廓檢測以及外接矩形,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 對for循環(huán)中表達式和循環(huán)體的執(zhí)行順序詳解

    對for循環(huán)中表達式和循環(huán)體的執(zhí)行順序詳解

    今天小編就為大家分享一篇對for循環(huán)中表達式和循環(huán)體的執(zhí)行順序詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • Qt學習教程之對話框消失動畫效果

    Qt學習教程之對話框消失動畫效果

    這篇文章主要給大家介紹了關于Qt學習教程之對話框消失動畫效果的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-07-07

最新評論