设顺序表 S 中元素递增有序,编写算法删除 S 所有大于 k1 且小于 k2 的元素
2013-06-01 18:24
751 查看
删除表中指定上限和下限之间的数据的功能由函数DeleteElem()实现,其算法思想:从表头向后逐个检查数据元素,找到第一个满足删除条件的数据元素;然后再找出满足条件的元素的个数,最后将被元素之后的元素一次性移动到位。
#include<stdio.h> #include<malloc.h> #include<time.h> #include<stdlib.h> #define LISTSIZE 50 typedef struct SqListNode { int *elem;//存储空间基址 int length;//顺序表的当前长度 int listsize;//顺序表的最大长度 }SqList; int InitList(SqList &List)//生成顺序表,表中元素随机生成,且从小到大有序 { int k,data; srand((unsigned)time(NULL)); List.length=0;//初始时表中无元素,置顺序表表长为 0 List.elem=(int *)malloc(LISTSIZE*sizeof(int));//为顺序表分配空间 for(k=0;k<30;k++)//为顺序表中的各元素赋值 { data=rand()%999+3;//生成随机数作为表中元素的值 int i=List.length; //按从小到大的顺序插入数据,寻找插入位置 while(List.elem[i-1] > data && i>0) { List.elem[i]=List.elem[i-1];i--;//后移元素 } List.elem[i]=data; List.length++;//表长加 1 } return 1; } int DisplayList(SqList List)//输出顺序中各元素的值 { int k; if(List.length == 0) { printf("当前表为空表!\n\n");return -1; } for(k=0;k<List.length-1;k++)//依次输出表中除最后一个元素外的所有元素值 { printf("%5d - ",List.elem[k]); } printf("%5d\n\n",List.elem[k]);//输出最后一个元素的值 return 1; } int DeleteElem(SqList &List)//删除表中指定上限和下限之间的数据 { int low,up,start=0,num=0,i; printf("你要删除哪个范围的数据,请输入:"); scanf("%d%d",&low,&up);printf("\n\n"); while(start < List.length && List.elem[start] <= low) start++; //在List中查找第一个大于low的元素的下标 if(start >= List.length) { printf("当前表中无满足要求的元素!\n\n");return -1; } for(i=start;i<List.length && List.elem[i]<up;i++) num++;//求表中值大于 low 小于 up 的元素的个数 if(num == 0)//若表中无大于 low 且小于 up 的元素则返回 { printf("表中无满足要求的元素!\n\n");return 0; } //被删除元素之后的元素一次性移动到位 for(i=start+num;i<=List.length-1;i++) List.elem[i-num]=List.elem[i]; List.length-=num; printf("删除指定元素后,表中剩余元素为:\n\n"); DisplayList(List);//输出顺序中各元素的值 return 1; } int main() { SqList List; InitList(List);//生成顺序表,表中元素随机生成,且从小到大有序 DisplayList(List);//输出顺序中各元素的值 DeleteElem(List); return 1; }
相关文章推荐
- 递增单链表删除所有大于mink且小于maxK的元素。
- 编写算法,对非递减顺序存储的线性表操作,将表中相等的多余元素删除,变为严格递增
- 长度为n的顺序表L,编写一个时间复杂度为O(n),空间复杂度为O(1)的算法,该算法删除线性表中所有值为X的元素
- 假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,请编写算法将A表和B表归并为一个按元素值递减 有序(即非递增有序,允许表中含有值相同的元素)排列的线性表C,并要求利用原装(即A表和
- 数据结构 2-11设顺序表va中的数据元素递增有序。试写一算法,将x插入到顺序表的适当位置上,以保持该表的有序性。
- 假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,请编写算法将A表和B表归并为一个按元素值递减 有序(即非递增有序,允许表中含有值相同的元素)排列的线性表C,并要求利用原装(即A表和
- 已知线性表中元素以值递增有序排列,并以单链表作为存储结构,设计一个算法,删除表中值相同的多余元素
- 要完整准确的 均以单链表作存储结构 试编写算法将A表和B表归并成一个按元素值递减有序的线性表C 【数据结构】假设有两个按元素值递增有序的线性表A和B 并要求利用原表的空间存放C。谁会么
- 假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,请编写算法将A表和B表归并为一个按元素值递减 有序(即非递增有序,允许表中含有值相同的元素)排列的线性表C,并要求利用原装(即A表和
- 数据结构 — 4.删除单链表中所有值大于mink且小于maxk的元素
- 删除递增线性表中值大于min且小于max的元素
- Java程序练习-删除所有大于mink且小于maxk的元素
- 设计删除顺序表中【x,y】中的所有元素算法
- 数据结构之从有序的顺序表中删除所有其值重复的元素,使表中的元素均不相同
- 设计一个算法,从顺序表中删除所有值为x的元素
- 设顺序表a中的数据元素递增有序,试设计一个算法,将x插入到顺序表的适当位置,以保持该表的有序性。
- 程序员面试题目总结--数组(一)【递归求数组所有元素和、用一个for循环打印出一个二维数组、用递归判断数组是否是递增、有序数组中删除重复元素】
- 编写一个算法,从顺序表中删除自第i个元素开始的k个元素
- 设顺序表va中的数据元素递增有序。试写一算法,将x插入到顺序表的适当位置上,以保持该表的有序性
- 数据结构:有人设计以下算法用于删除整数顺序表L中所有值在[x,y]范围内的元素,该算法显然不是高效的,请设计一个同样功能的高效算法。