顺序表 增删改操作

1.从键盘依次输入10个整数(彼此以若干空格隔开),在内存中建立一个顺序表。然后完成以下操作:
① 查找:输入一个欲查找的整数,找到则显示第一个相匹配的整数在顺序表中所处的位置,若不存在,则显示"Not Found"。
② 删除:输入一个表示欲删除整数的位置的整数i(注意i的合法性),在顺序表中删除该数,并保证删除后依然是顺序表。
③ 插入:输入一个欲插入位置i和欲插入元素e,将e插入到第i个整数之前(注意i的合法性)。

  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #define  MAXSIZE  30
  4 typedef int DataType;
  5 
  6 typedef  struct  node 
  7 {   
  8     DataType  data[MAXSIZE];
  9     int  length;
 10 } SeqList,* PSeqList;
 11 //typedef SeqList* PSeqList;
 12 
 13 
 14 PSeqList  Init_SeqList( );
 15 PSeqList  Create_SeqList(PSeqList PL);
 16 int Location_SeqList (PSeqList PL, DataType  x);
 17 int Delete_SeqList(PSeqList PL,int i );
 18 int  Insert_SeqList(PSeqList PL,int i,DataType  x);
 19 Print_SeqList(PSeqList PL);
 20 
 21 main()
 22 {
 23    int t=1;
 24    int op;
 25    DataType x;
 26    int flag;
 27    int l;
 28    PSeqList PL;
 29    
 30          
 31          while(t)
 32        {
 33             printf("\n\n\n\n");
 34             printf("\t\t\t---顺序表---\n");
 35             printf("\n\t\t\t*******************************************");
 36             printf("\n\t\t\t*          1---初始化及创建                  *");
 37             printf("\n\t\t\t*          2---查找                  *");
 38             printf("\n\t\t\t*          3---删除                  *");
 39             printf("\n\t\t\t*          4---插入                 *");
 40             printf("\n\t\t\t*          0---退     出                  *");
 41             printf("\n\t\t\t*******************************************");
 42             printf("\t\t\t请选择菜单号(0--4):");
 43             scanf("%d",&op);
 44             switch(op)
 45             {
 46    
 47     case 1:
 48         PL=Init_SeqList();//初始化顺序表
 49         PL=Create_SeqList(PL);
 50         printf("新创建的顺序表为:");
 51         Print_SeqList(PL);
 52         break;
 53         
 54     case 2:
 55         printf("查找\n");
 56         printf("请输入待查找元素x\n");
 57         scanf("%d",&x);//输入待查找数值
 58         Print_SeqList(PL);
 59         flag=Location_SeqList (PL,x);//调用查找函数
 60         if(!flag)
 61               printf("Not Found\n");
 62         else
 63               printf("待查找的x在顺序表中的位置为%d\n",flag);
 64         break;
 65 
 66     case 3:
 67         printf("删除\n");
 68         printf("请输入待删除元素的位置l:\n");
 69         scanf("%d",&l);
 70         Delete_SeqList(PL,l);//调用删除函数
 71         Print_SeqList(PL);
 72         break;
 73 
 74     case 4:
 75         printf("插入\n");
 76         printf("请输入待插入元素的位置l:");
 77         scanf("%d",&l);
 78         printf("请输入待插入的元素x:");
 79         scanf("%d",&x);
 80         Insert_SeqList(PL,l,x);
 81         Print_SeqList(PL);
 82         break;
 83     case 0:
 84           t=0;
 85           printf("\n\t\t\t程序结束!\n");
 86           break;
 87           
 88     default: 
 89         printf("\n\t\t\t\t输入错误!请重新输入!\n");
 90         break;
 91 
 92    }
 93        
 94        }
 95 
 96 
 97 }
 98 
 99 
100 
101 PSeqList  Init_SeqList(void)
102 {  /*创建一顺序表,入口参数无,返回一个指向顺序表的指针,指针值为零表示分配空间失败*/
103    PSeqList  PL;
104    PL=( PSeqList )malloc(sizeof(SeqList)); 
105    if (PL)       /*若PL=0表示分配失败*/
106         PL->length=0;     
107    return (PL);
108 } 
109 
110 PSeqList  Create_SeqList(PSeqList PL)
111 {
112        int i,n;
113        printf("请输入需初始化的元素个数\n");
114        scanf("%d",&n);
115        printf("请输入%d个整数,中间用空格隔开:\n",n);
116        for(i=0;i<n;i++)//输入10个整数
117        { 
118            scanf("%d",&PL->data[i]);
119            PL->length++; 
120        }
121        return (PL);
122 
123 
124 }
125 
126 int Location_SeqList (PSeqList PL,DataType  x)
127 {  /*顺序表检索,入口参数:为顺序表指针,检索元素,返回元素位置,-1表示表不存在,0表示查找失败*/
128     int i;
129     if (! PL) 
130     {  
131        printf("表不存在"); 
132        return(-1); /*表不存在,不能检索*/
133      } 
134    i=0;
135    while (i<PL-> length && PL->data[i]!= x)
136              i++;
137    if (i>=PL-> length)             
138        return 0;
139    else              
140        return (i+1);  
141 
142 }
143 
144 int Delete_SeqList(PSeqList PL,int i)
145 {  /*顺序表删除,入口参数:顺序表指针,删除元素位置,返回标志1表示成功,0表示删除位置不合法,-1表示表不存在*/
146     int  j;
147     if (! PL)
148     { 
149        printf("表不存在"); 
150        return(-1);    /*表不存在,不能删除元素*/
151     }
152     if(i<1 || i> PL -> length)  /*检查删除位置的合法性*/
153     {  
154         printf ("删除位置不合法"); 
155         return(0);
156     } 
157     //*x= PL ->data[i-1];
158     for(j=i;j< PL -> length; j++)
159          PL ->data[j-1]=PL ->data[j];    //向上移动
160     PL-> length --;    
161     return (1);        /*删除成功*/
162 } 
163 
164 int  Insert_SeqList(PSeqList PL,int i,DataType  x)
165 {   /*顺序表插入,入口参数:顺序表指针,插入位置,插入元素,返回标志,1表示成功,0表示插入位置不合法,-1表示溢出,-2表示表不存在*/
166      int j;
167      if (!PL)
168      {
169            printf("表不存在");
170            return(-2);      /*表不存在,不能插入*/
171       }  
172      if (PL-> length >= MAXSIZE)
173      { 
174           printf("表溢出"); 
175           return (-1);       /*表空间已满,不能插入*/
176      } 
177 
178      if(i<1||i>PL->length+1)
179      {
180       printf("插入位置不合法"); 
181       return(0); 
182      } 
183 
184      for(j= PL->length-1;j>=i-1;j--) 
185           PL->data[j+1]= PL ->data[j];   //移动元素
186      PL->data[i-1]=x;//PL->data[i-1]=x;  
187      PL->length++;
188      return (1);
189 } 
190 
191 Print_SeqList(PSeqList PL)
192 {
193     int i;
194     if(!PL)
195     {
196         printf("无此顺序表");
197         return -1;
198     }
199     if(PL->length==0)
200     {
201         printf("空表");
202         return 0;
203     }
204 
205     printf("顺序表的长度为%d",PL->length);
206     printf("顺序表的各元素值为:");
207     for(i=0;i<=PL->length-1;i++)
208         printf("%4d",PL->data[i]);
209     return 1;
210 
211 }

 

posted @ 2017-03-20 10:51  不忘_初芯  阅读(734)  评论(0编辑  收藏  举报