栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

数据结构第二章课后习题第十题(删除顺序表中值为item的元素)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数据结构第二章课后习题第十题(删除顺序表中值为item的元素)

已知长度为n的线性表A采用顺序存储结构,请写一时间复杂度为O(n)、空间复
杂度为O(1)的算法,该算法删除线性表中所有值为item的数据元素。


#include 
#define ok 1
#define error 0
#define overflow -2
#define MaxSize 100

using namespace std;
typedef int status;
typedef int ElemType;

//定义
typedef struct
{
    ElemType *elem;
    int length;
}SqList;

//初始化
status InitList(SqList &L)
{
    L.elem = new ElemType[MaxSize];
    if (!L.elem)
       return overflow;
    int length = 0;
    return ok;
}

//创建
status CreatList(SqList &L, int n)
{
    if (!L.elem)
        return error;
    for (int i = 0; i < n; i++)
        cin >> L.elem[i];
    L.length = n;
    return ok;
}


//void deleteitem(SqList &L, ElemType item)
//{  //删除顺序表L中所有值为item的元素
//    int k = 0, i;                           // 记录值不等于item的个数
//	for (i = 0; i < L.length; i++)
//	{
//		if (L.elem[i] != item )
//	    {
//	    	L.elem[k] = L.elem[i];
//	    	cout << L.elem[k] << ' ';
//		}	
//		k++;                               //不等于x的元素增1 
//	}
//	L.length = k;                          //顺序表L的长度等于k 
//}


void deleteitem(SqList &L, ElemType item)
{
	int k = 0, i = 0;                               //k记录等于item的元素个数 
	while (i < L.length)
	{
		if (L.elem[i] == item)
		    k++;
		else
		{
			L.elem[i - k] = L.elem[i];         //当前元素前移k个位置 
			cout << L.elem[i - k] << ' ' ;
		}
		i++;
	}
	L.length = L.length - k;                   //顺序表的长度递减 
}


int main()
{
    int n, item, j ;
    SqList L;
    InitList(L);
    cout << "输入顺序表长度:" << endl;
    cin >> n;
    cout << "输入顺序表元素:" << endl;
    CreatList(L, n);

    cout << "输入要删除的元素:" << endl;
    cin >> item;
    cout << "输出删除后的顺序表元素:" << endl;
    deleteitem(L, item);
    
    return ok;
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/832788.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号