亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++簡單集合類的實現(xiàn)方法

 更新時間:2016年07月08日 16:16:08   投稿:lijiao  
如何使用C++實現(xiàn)一個簡單的集合類,這篇文章主要介紹了C++簡單集合類的實現(xiàn)方法,感興趣的小伙伴們可以參考一下

來自于C++程序設計的一個題目。實現(xiàn)一個集合類,要求實現(xiàn)以下4個操作。
 1.向集合中添加元素,如果集合中已存在元素則不添加
 2.從集合中移除元素,移除之前需要先判斷集合中元素是否存在
 3.重載+運算符,用以實現(xiàn)集合的求并集運算
 4.重載*運算符,用以實現(xiàn)集合的求交集運算 

1.類的整體設計
該問題需要模擬實現(xiàn)集合類,我們可以使用數(shù)組來模擬集合,于是使用int items[100]用來存放集合中的數(shù)據(jù)。為了實現(xiàn)數(shù)組的遍歷,這就需要一個整數(shù)用來表示數(shù)組中元素的個數(shù),于是使用int number來表示數(shù)組中元素的個數(shù);此外,為了實現(xiàn)題目的需求,設計以下四個函數(shù):
 1).使用add_item(int item)成員函數(shù)向數(shù)組中添加元素
 2).使用remove_item(int item)成員函數(shù)向數(shù)組中移除元素
 3).重載operator+表示集合的求并集運算
 4).重載operator*表示集合的求交集運算
由于向集合添加元素之前,必須確保集合中不存在該元素;在從集合中移除元素之前,必須確保集合中存在該元素,因此添加is_exist(int item)方法用以判斷集合中是否存在這個元素;此外為了顯示集合,添加display()方法, 基本設計如下:

 class Set
{
public:
  int items[100]; //定義一個數(shù)組作為容器存放100個集合元素
  int number; //定義數(shù)字i表示集合中元素的個數(shù)
  //構造函數(shù)和析構函數(shù)
  Set() {
    this->number = 0;
    memset(this->items,0,sizeof(items));
  }
  //初始化方法
  int init(int items[], int num);
  //添加元素
  bool add_item(int item);
  //刪除元素
  bool remove_item(int item);
  //求集合的并集
  Set operator+ (Set set2);
  //求集合的交集
  Set operator* (Set set2);
  //顯示集合元素
  int display();
  //判斷集合當中是否存在item,返回元素在集合中的位置,不存在返回-1
  int is_exist(int item);
}; 

2.構造函數(shù)

 Set() {
  this->number = 0;
  memset(this->items,0,sizeof(items));
} 

在構造函數(shù)中,我們對數(shù)組進行初始化,聲明完數(shù)組之后,如果不進行初始化,數(shù)組元素是隨機值,在C語言中,變量不進行初始化都會被分配隨機值。為了避免這種情況,我們使用memset函數(shù)對數(shù)組items所有元素全部賦值為0;同時,由于此時數(shù)組中沒有元素,即元素個數(shù)為0,我們的number也應當賦值為0. 

3.判斷數(shù)組中是否包含元素 item

 int Set::is_exist(int item)
{
  for(int i=0; i< this->number; i++) {
    if(this->items[i] == item) {
      return i;
    }
  }
  return -1;
} 

該函數(shù)用于判斷數(shù)組中是否存在item元素,如果存在就返回item元素的位置,如果不存在就返回-1. 判斷方法非常簡單,寫一個for循環(huán)從items[0]-items[number-1]一個一個進行遍歷。如果相等,直接返回i,此時i就是數(shù)組中item元素的位置;如果遍歷完整個數(shù)組之后,都沒有發(fā)現(xiàn)與item相等的數(shù)組元素,說明數(shù)組中不存在item這個元素,于是返回-1. 

4.向數(shù)組中添加元素

 bool Set::add_item(int item)
{
  if(is_exist(item) >= 0 || this->number >= 100) {
    return false;
  }
  this->items[this->number] = item;
  this->number++;
  return true;
} 

首先判斷數(shù)組中是否存在該元素,如果存在則不能再向集合中添加元素,直接返回false,如果不存在,則向數(shù)組中的number所指向的那個位置添加該元素,然后number作為數(shù)組元素個數(shù)的指示器+1,這樣就完成了添加元素。 

5.保護數(shù)組元素不被修改
寫到這里,我們發(fā)現(xiàn),數(shù)組元素個數(shù)指示器this->number,對于該問題的幾個算法都起到了核心的作用,首先,我們依賴于數(shù)組元素個數(shù)指示器遍歷數(shù)組,如果number值遭到修改,會導致無法遍歷數(shù)組。舉個例子來說,當我們調(diào)用下列語句以后:

 Set set1;
set1.add_item(1);
set1.add_item(2);
set1.add_item(3); 

集合set1中的數(shù)組items變?yōu)閇1,2,3],數(shù)組元素個數(shù)指示器number=3,此時,如果我們還想向集合set1中添加元素20,我們需要利用number=3這個指示器,讓set1.items[number]=20,并且讓number+1以指向下一個位置,即number=4。但是如果用戶手動修改number值,比如set1.number=50;此時,我們的number就不再能指示數(shù)組元素的正確位置,從而導致以上所有算法所依賴的number失效,因此,我們需要對數(shù)組本身,以及數(shù)組元素個數(shù)指示器number進行私有化,以避免用戶隨意篡改。于是:

 class Set
{
public:
  //構造函數(shù)和析構函數(shù)
  Set() {
    this->number = 0;
    memset(this->items,0,sizeof(items));
  }
  //初始化方法
  int init(int items[], int num);
  //添加元素
  bool add_item(int item);
  //刪除元素
  int remove_item(int item);
  //求集合的并集
  Set operator+ (Set set2);
  //求集合的交集
  Set operator* (Set set2);
  //顯示集合元素
  int display();
  //判斷集合當中是否存在item,返回元素在集合中的位置,不存在返回-1
  int is_exist(int item);
private:
  int items[100]; //定義一個數(shù)組作為容器存放100個集合元素
  int number; //定義數(shù)字i表示集合中元素的個數(shù)
}; 

6. 從集合中移除元素

 bool Set::remove_item(int item)
{
  int pos = is_exist(item);
  if(pos == -1) return false;
  for(int i=pos; i< this->number-1; i++) {
    this->items[i] = this->items[i+1];
  }
  this->number--;
  return true;
} 

首先檢查要移除的元素在結(jié)合中是否存在,如果不存在,則直接返回false;其次,定位到集合中元素的位置,然后從這個位置開始將集合中剩余的元素逐個前移,最后集合元素指示器-1,并返回true.

7. 求兩個集合的交集

 Set Set::operator* (Set set2)
{
  Set result;
  for(int i=0; i< this->number; i++) {
    if(set2.is_exist(this->items[i]) >= 0) {
      result.items[result.number] = this->items[i];
      result.number++;
    }
  }
  return result;
} 

算法很簡單,遍歷集合A中的元素,對于A中的每一個元素判斷在集合B中是否存在,如果存在就加入到集合C當中,最后返回集合C

8. 求兩個集合的并集

 Set Set::operator+ (Set set2)
{
  Set result;
  for(int i=0; i<this->number; i++) {
    result.items[result.number] = this->items[i];
    result.number++;
  }
  for(int j=0; j<set2.number; j++) {
    if(result.is_exist(set2.items[j]) == -1) {
      result.items[result.number] = set2.items[j];
      result.number++;
    }
  }
  return result;
} 

首先遍歷集合A,將集合A中的元素全部加到集合C當中,然后遍歷集合B,對于B中的每一個元素,首先判斷是否在A中存在,如果不存在則將其加入到集合C中,最終返回集合C

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C語言文件操作 fopen, fclose, mkdir詳解

    C語言文件操作 fopen, fclose, mkdir詳解

    本文給大家詳細介紹了下C語言的文件操作函數(shù)fopen, fclose, mkdir的用法及示例,非常的簡單實用,有需要的小伙伴可以參考下。
    2016-03-03
  • C++ 類的繼承與派生實例詳解

    C++ 類的繼承與派生實例詳解

    這篇文章主要介紹了 C++ 類的繼承與派生實例詳解的相關資料,需要的朋友可以參考下
    2017-06-06
  • 深入了解C++函數(shù)重載解析策略

    深入了解C++函數(shù)重載解析策略

    這篇文章主要為大家詳細介紹了C++中函數(shù)重載的解析策略,文中的示例代碼講解詳細,對我們學習C++有一定幫助,感興趣的小伙伴可以了解一下
    2022-10-10
  • 數(shù)據(jù)結(jié)構之伸展樹詳解

    數(shù)據(jù)結(jié)構之伸展樹詳解

    這篇文章主要介紹了數(shù)據(jù)結(jié)構之伸展樹詳解,本文對伸展樹(Splay Tree)的單旋轉(zhuǎn)操作、一字型旋轉(zhuǎn)、之字形旋轉(zhuǎn)區(qū)間操作等理論知識做了講解,并給出實現(xiàn)代碼,需要的朋友可以參考下
    2014-08-08
  • 利用Matlab仿真實現(xiàn)圖像煙霧識別(k-means聚類圖像分割+LBP+PCA+SVM)

    利用Matlab仿真實現(xiàn)圖像煙霧識別(k-means聚類圖像分割+LBP+PCA+SVM)

    本文主要介紹了利用k-means聚類實現(xiàn)圖像分割+LBP算法進行特征提取+PCA算法進行特征降維+SVM算法訓練二分類模型從而實現(xiàn)煙霧識別。文中介紹很詳細,感興趣的朋友可以了解一下
    2021-12-12
  • C++ 類的友元機制解讀

    C++ 類的友元機制解讀

    這篇文章主要介紹了C++ 類的友元機制的相關資料,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下
    2021-02-02
  • 關于C++虛繼承的內(nèi)存模型問題

    關于C++虛繼承的內(nèi)存模型問題

    C++虛繼承的內(nèi)存模型是一個老生常談的話題,實現(xiàn)方法主要依賴于編譯器,本文從多個角度通過代碼詳解C++中虛繼承的內(nèi)存模型知識,感興趣的朋友跟隨小編一起看看吧
    2021-07-07
  • C++中隱式類型轉(zhuǎn)換學習筆記

    C++中隱式類型轉(zhuǎn)換學習筆記

    在本篇文章里小編給大家整理的是一篇關于C++中隱式類型轉(zhuǎn)換學習筆記內(nèi)容,有興趣的跟著小編來學習下吧。
    2020-02-02
  • Qt跨平臺窗口選擇功能的實現(xiàn)過程

    Qt跨平臺窗口選擇功能的實現(xiàn)過程

    很多時候為了方便軟件的使用,我們需要讓編寫的界面程序顯示在最上層,這時候就需要對窗口屬性進行調(diào)整,下面這篇文章主要給大家介紹了關于Qt跨平臺窗口選擇功能的實現(xiàn)過程,需要的朋友可以參考下
    2022-12-12
  • C++?qsort函數(shù)排序與冒泡模擬實現(xiàn)流程詳解

    C++?qsort函數(shù)排序與冒泡模擬實現(xiàn)流程詳解

    qsort是一個庫函數(shù),基于快速排序算法實現(xiàn)的一個排序的函數(shù),下面這篇文章主要給大家介紹了關于C語言qsort()函數(shù)使用的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-10-10

最新評論