IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 数据结构集合 -> 正文阅读

[数据结构与算法]数据结构集合

这个章节没听课很迷

集合的基本概念:

1.集合的成员必须互不相同,成员一般是无序的,没有先后次序的关系

2.表示方法:{1,2,3,4,5,6,7,8,9,10}

目录

顺序存储结构

定义代码实现(利用vector)

删(vector删除一个元素用erase()函数)

链式结构

并查集


集合的存储结构有两种:顺序存储与链式存储


顺序存储结构

定义代码实现(利用vector)

class Set
{
public:
	virtual void makeEmpty() = 0;
	virtual bool addMember(int x) = 0;
	virtual bool delMember(int x) = 0;
//  virtual void intersect(Set & r) = 0 ;
//  virtual void union(Set & r) = 0 ;
//  virtual void difference(Set & r) = 0 ;
	virtual bool contains(int x)=0;
//其他方法的声明;
};

//组合复用vector来实现集合
class VectorSet : public Set
{
public:
	VectorSet()
	{		setSize = 0 ;
	}
	virtual void makeEmpty() 
	{		setSize = 0;
		elem.clear();
	}
private:
	int setSize; //集合元素数目
	vector<int>  elem;

}

由于课程要求,我就实现集合的增删查并交

virtual bool addMember(int x) 
{	//要考虑集合中没有重复元素。
	vector<int>::iterator  pos;  //迭代器
	pos = find(elem.begin(),elem.end(),x);
	if (pos == elem.end())
	{
		++setSize;
		elem.push_back(x);		
		return true;
	}
	else 
        return false ; //元素已经在集合中,添加失败

}
	

删(vector删除一个元素用erase()函数)

virtual bool delMember(int x) 
{			
    vector<int>::iterator  pos;
	pos = find(elem.begin(),elem.end(),x);//找到x的位置
	if (pos != elem.end())
	{
        elem.erase(pos); //删除该位置的元素
		--setSize;
		return true;
    }
	else 
        return flase;
}

virtual bool contains(int x)
{	
    vector<int>::iterator  pos;
	pos = find(elem.begin(),elem.end(),x);
	if (pos == elem.end()) 
        return false;
	else 
        return true;
}

void Union ( Vectorset& LA,Vectorset& LB ) {
    int n1 = LA.setsize, n2 = LB.setsize;
    int i, k, x;
    for ( i = 0; i < n2; i++ ) {
        x = LB.elem[i]; //在LB中取一元素
        k = LA.contains(x); //在LA中搜索它
        if (k == 0) //若在LA中未找到插入它
        { 
        LA.addMember(x); LA.setsize++; 
        }
        //插入到第n个表项位置
    }
}

void Intersection( Vectorset& LA,Vectorset& LB ) {
    int n1 = LA.setsize;
    int i=0, k, x;
    while(i<n1){
        x=LA.elem[i];
        k = LB.contains(x); //在LA中搜索它
        if (k == 0) //若在LA中未找到插入它
        { 
            LA.delMember(x); 
            LA.setsize--; 
        }
    }
}

链式结构

也可以实现增删查并交

下面这个链式集合默认实现了排序。。。

class Set
{
public:
	virtual void makeEmpty() = 0;
	virtual bool addMember(int x) = 0;
	virtual bool delMember(int x) = 0;
//  virtual void intersect(Set & r) = 0 ;
//  virtual void union(Set & r) = 0 ;
//  virtual void difference(Set & r) = 0 ;
	virtual bool contains(int x)=0;
//其他方法的声明;
};

template <class T>
struct LinkNode { //链表结点类的定义
    T data; //数据域
    LinkNode<T> * link; //链指针域
};

template <class T>
class ListSet : public Set
{
public:
	ListSet() { first = new LinkNode<T>; } //构造函数
    ListSet(T x) { first = new LinkNode<T>(x); }
	virtual void makeEmpty();
protected:
	LinkNode<T> * first; //表头指针

}

template <class T>
bool LinkedSet<T>::addMember(const T& x) {
//把新元素x加入到集合之中
      
     LinkNode<T> *p = first->link, *pre = first;

     while (p != NULL && p->data < x)   //当data等于x时退出,循链扫描
     { 
        pre = p;  
        p = p->link; 
     }		
     if (p != NULL && p->data == x) 
          return false;	//集合中已有此元素, 不加入
     
     LinkNode<T> *s = new LinkNode(x);    //创建结点
     s->link = p;  
     pre->link = s;	 	     //链入
     if (p == NULL) 
            last = s;	    //链到链尾时改链尾指针
     return true;
};

template <class T>
bool LinkedSet<T>::delMember (const T& x) {
//把集合中成员x删去
     LinkNode<T> *p = first->link,  *pre = first;
     while (p != NULL && p->data < x)    //循链扫描
     { 
         pre = p;  
         p = p->link;//快慢指针
     }		
     if (p != NULL && p->data == x) {     //找到,可删
          pre->link = p->link;   //利用前后指针进行删除
          if (p == last) 
          last = pre;	//删链尾时改尾指针
          delete p;     //删除含x结点
          return true;						
     }
     else 
        return false;		//集合中无此元素
};

template <class T>
bool LinkedSet<T>::contains(const T& x) {
//把集合中成员x删去
     LinkNode<T> *p = first->link,  *pre = first;
     while (p != NULL && p->data < x)    //循链扫描
     { 
         pre = p;  
         p = p->link;//快慢指针
     }		
     if (p != NULL && p->data == x) {     //找到
        return true;		
     }
     else 
        return false;		//集合中无此元素
};

和上面的顺序结构的集合的'并'很像

主要思想是,先进行LA中链表的循环(到link指针为空截止)

{

每次取出LA的一个节点,在LB链表中查找,若查找到就continue继续下一步

若未查找到就插入到LB链表末尾

}

(快慢指针在链表操作的作用很高效,恰好就可以找到某节点的前驱节点)

这个交就要利用快慢指针进行删除。。

主要思想是,先进行LA中链表的循环(到link指针为空截止)

{

每次取出LA的一个节点,在LB链表中查找,

若查找到就在LB链表删除掉这个节点

若未查找到continue继续下一步

}

并查集

即将编号为1…N的N个对象划分为不相交集合,在每个集合中,选择其中某个元素代表所在集合。


? 并查集是一种树型的数据结构,用于处理一些不相交集合的合并问题。


? 并查集的主要操作有

(考点)
? 1-合并两个不相交集合(合并过程)
? 2-判断两个元素是否属于同一个集合(查找过程)------
Kruskal算法(图最小生成树)
? 3-路径压缩

例子:?

并查集这篇文章很好,我直接转了

【算法与数据结构】—— 并查集_the_ZED的博客-CSDN博客_并查集

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-12-13 13:06:58  更:2021-12-13 13:09:24 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 3:26:50-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码