C++教程
C++控制语句
C++函数
C++数组
C++指针
C++对象
C++继承
C++多态
C++抽象
C++常用
C++ STL教程
C++迭代器
C++程序

C++ Set 为空()

C++ Set empty()

C++ " empty()函数用于检查set容器是否为空。如果 Set 的容器为空(大小为0),则返回 true ;否则,返回 false 。

语法

bool empty() const;               // until C++ 11
bool empty const noexcept;    //since C++ 11

参数

返回值

如果返回,则返回 true set容器为空(大小为0),否则返回 false 。

复杂度

常量。

迭代器有效性

没有更改。

数据争用

已访问容器。
同时访问set的元素是安全的。

异常安全性

此函数绝不会引发异常。

示例1

让我们看一个简单的示例,以检查集合是否包含任何元素:
#include <set>
#include <iostream>
using namespace std;
int main()
{
    set<int> numbers;
    cout << " Initially, numbers.empty(): " << numbers.empty() << "\n";
    numbers = {100, 200, 300};
    cout << "\n After adding elements, numbers.empty(): " << numbers.empty() << "\n";
}
输出:
 Initially, numbers.empty(): 1
 After adding elements, numbers.empty(): 0
在上面的示例中,set的初始大小为0,因此,empty()函数返回1(true),添加元素后返回0(false)。

示例2

让我们看一个简单的示例来检查set是否为空:
#include <iostream>
#include <set>
using namespace std;
int main(void) {
   set<char> s;
   if (s.empty())
      cout << "Set is empty." << endl;
   s = {100};
   if (!s.empty())
      cout << "Set is not empty." << endl;
   return 0;
}
输出:
Set is empty
Set is not empty
在上面的示例中,如果使用了条件语句。如果set为空,则在添加元素之后将返回set为空。

示例3

让我们看一个简单的示例:
#include <iostream>
#include <set>
using namespace std;
int main ()
{
  set<int> myset;
  myset = {100, 200, 300};
  while (!myset.empty())
  {
    cout << *myset.begin()<< '\n';
    myset.erase(*myset.begin());
  }
  return 0;
}
输出:
100
200
300
在上面的示例中,它仅在while循环中使用empty()函数,并打印set的元素,直到set不为空为止。

示例4

让我们看一个简单的例子:
#include <iostream>
#include <set>
#include <string>
using namespace std;
int main() {
  typedef set<int> phoneSet;
   
   int number;
   phoneSet phone;
   
   if (phone.empty())
      cout << "Set is empty. Please insert content! \n " << endl;
   
   cout<<"Enter three sets of number: \n";
   
   for(int i =0; i<3; i++)
   {
       cin>> number;    // Get value
       phone.insert(number);   // Put them in set
   }
   if (!phone.empty())
   {
      cout<<"\nList of telephone numbers: \n";
      phoneSet::iterator p;
      for(p = phone.begin(); p!=phone.end(); p++)
      {
          cout<<(*p)<<" \n ";
      }
   }
   return 0;
}
输出:
Set is empty. Please insert content! 
 
Enter three sets of number: 
1111
5555
3333
List of telephone numbers: 
1111 
3333 
5555 
在上面的示例中,该程序首先使用三组数字交互创建电话机,然后检查该电话机是否为空。如果set为空,则显示一条消息,否则,显示set中所有可用的电话号码。

昵称: 邮箱:
Copyright © 2022 立地货 All Rights Reserved.
备案号:京ICP备14037608号-4