顺序表1-1
2016-04-09 14:55
260 查看
注意:len必须为加*,因为数据长度是随着插入或者删除是会变的,只有把len声明为指针型,才会一起变。
#include"stdio.h"
#define MaxSize 10
void inserElem(int sqlist[], int *len, int i, int x)
{
int t;
if (*len == MaxSize || i<1 || i>*len + 1)
{
printf("this insert is illegal\n");
return;
}
for (t = *len - 1; t >= i - 1; t--)
sqlist[t + 1] = sqlist[t];
sqlist[i - 1] = x;
*len = *len + 1;
}
void DelElem(int sqlist[], int *len, int i)
{
int j;
if (i<1 || i>*len)
{
printf("this delelem is illegal");
return;
}
for (j = i; j <*len - 1; j++)
sqlist[j - 1] = sqlist[j];
return;
}
int main()
{
int sqlist[MaxSize];
int len;
int i;
for (i = 0; i < 6; i++)
scanf_s("%d", &sqlist[i]);
len = 6;
for (i = 0; i < len; i++)
{
printf("%d ", sqlist[i]);
}
printf("\nthe space length is %d\n", MaxSize - len);
inserElem(sqlist, &len, 3, 0);
for (i = 0; i < len; i++)
printf("%d ", sqlist[i]);
printf("\nthe space is %d\n", MaxSize - len);
inserElem(sqlist, &len, 11, 0);
DelElem(sqlist, &len, 6);
for (i = 0; i < len; i++)
printf("%d ", sqlist[i]);
printf("\nthe space length is %d \n", MaxSize - len);
return 0;
}
#include"stdio.h"
#define MaxSize 10
void inserElem(int sqlist[], int *len, int i, int x)
{
int t;
if (*len == MaxSize || i<1 || i>*len + 1)
{
printf("this insert is illegal\n");
return;
}
for (t = *len - 1; t >= i - 1; t--)
sqlist[t + 1] = sqlist[t];
sqlist[i - 1] = x;
*len = *len + 1;
}
void DelElem(int sqlist[], int *len, int i)
{
int j;
if (i<1 || i>*len)
{
printf("this delelem is illegal");
return;
}
for (j = i; j <*len - 1; j++)
sqlist[j - 1] = sqlist[j];
return;
}
int main()
{
int sqlist[MaxSize];
int len;
int i;
for (i = 0; i < 6; i++)
scanf_s("%d", &sqlist[i]);
len = 6;
for (i = 0; i < len; i++)
{
printf("%d ", sqlist[i]);
}
printf("\nthe space length is %d\n", MaxSize - len);
inserElem(sqlist, &len, 3, 0);
for (i = 0; i < len; i++)
printf("%d ", sqlist[i]);
printf("\nthe space is %d\n", MaxSize - len);
inserElem(sqlist, &len, 11, 0);
DelElem(sqlist, &len, 6);
for (i = 0; i < len; i++)
printf("%d ", sqlist[i]);
printf("\nthe space length is %d \n", MaxSize - len);
return 0;
}
相关文章推荐
- SizeClasses
- 【计算机网络】:计算机网络之路由协议之我见
- Android任性进程管理之不需要太多的剩余内存
- myeclipse workspace编码设置为gbk
- 连外网
- 个人项目框架搭建 -- 缓存接口与实现
- Linux内核如何装载和启动一个可执行程序
- [置顶] iOS开发参考
- 深入理解javascript原型和闭包系列 系深入理解javascript原型和闭包(17)——补充:上下文环境和作用域的关系
- Linux分区
- MySQL索引背后的数据结构及算法原理
- 汇编基础知识(二)
- mysql sql优化
- Linux 之Cut命令详解
- leetcode 198. House Robber
- kafka分布式搭建
- Git 常用指令
- 【Python笔记】图片处理库PIL的源代码安装步骤
- MsysGit下GUI乱码问题解决
- 深入理解javascript原型和闭包系列 深入理解javascript原型和闭包(16)——补this