前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >线性表的基本操作

线性表的基本操作

作者头像
用户2417870
发布2019-09-18 11:42:05
3330
发布2019-09-18 11:42:05
举报
文章被收录于专栏:g歌德ag歌德a

实现线性表的增加删除定位等功能。(编译执行环境vc6.0,因为目标院校上机考是用这个版本的)

代码语言:javascript
复制
 1 #include<stdio.h>
 2 #include<malloc.h>
 3 #define Maxsize 100
 4 
 5 typedef struct{
 6     int array[Maxsize];
 7     int length;
 8 }SQlist;
 9 
10 int findElem(SQlist L,int x)
11 {
12     int i=0;
13     for(i; i<L.length;++i)
14     {
15         if(x<L.array[i])
16         {
17             return i;
18         }
19     }
20     
21     return i;
22 }
23 
24 void insertElem(SQlist &L,int x)
25 {
26     int p,i;
27 
28     p=findElem(L,x);
29 
30     for(i=L.length-1;i>=p;--i)
31     {
32         L.array[i+1]=L.array[i];
33     }
34 
35     L.array[p]=x;
36     ++(L.length);
37 }
38 
39 int deleteElem(SQlist &L,int p,int &e)
40 {
41     int i;
42     if(p<0 || p>L.length-1)
43         return 0;
44     p=p-1;
45     e=L.array[p];
46 
47     for(i=p; i<L.length ;i++)
48     {
49         L.array[i]=L.array[i+1];
50 
51     }
52     --L.length;
53     return 1;
54 
55 }
56 void main()
57 {
58     SQlist *s=(SQlist*)malloc(sizeof(SQlist));
59 
60     for(int i=0;i<6;i++)
61     {
62         s->array[i]=(i+3);
63         printf("%d  ",s->array[i]);
64     }
65     printf("\n");
66     s->length=6;
67     insertElem(*s,15);
68 
69     
70     printf("增加后字符串为:");
71     for(int j=0;j<s->length;j++)
72     {
73         printf("%d  ",s->array[j]);
74     }
75     printf("\n");
76     printf("增加后字符串长度为%d\n",s->length);
77     int n;
78     deleteElem(*s,2,n);
79 
80     printf("%d\n",n);
81     for(int k=0;k<s->length;k++)
82     {
83         printf("%d  ",s->array[k]);
84     }
85 
86 }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档