Advertisement
ANTAR_NANDI

STL Set

Apr 5th, 2025 (edited)
12
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.54 KB | Software | 0 0
  1. /// *** --- ||| In the name of ALLAH ||| --- *** ///
  2.  
  3.  
  4.  
  5. #include<bits/stdc++.h>
  6. using namespace std;
  7.  
  8.  
  9. int main()
  10. {
  11. /// Declaration of set of integers
  12. set<int> s = { 1, 1, 2, 1, 3 };
  13.  
  14. /// Printing size and elements
  15. cout << s.size() << endl;
  16. for ( auto u : s ) cout << u << " "; /// 1 2 3
  17. cout << endl;
  18.  
  19. set<int>:: iterator it;
  20. for ( it = s.begin(); it != s.end(); it++ ) cout << *it << " "; /// 1 2 3
  21. cout << endl;
  22.  
  23. /// clearing and checking is empty set
  24. s.clear();
  25. cout << s.empty() << endl; /// 1
  26.  
  27. /// inserting in set
  28. s.insert ( 1 );
  29. s.insert ( 1 );
  30. s.insert ( 1 );
  31. s.insert ( 2 );
  32. s.insert ( 1 );
  33. s.insert ( 3 );
  34.  
  35. cout << s.size() << endl; /// 3
  36. for ( auto u : s ) cout << u << " "; /// 1 2 3
  37. cout << endl;
  38.  
  39. /// checking is specific element is in a set
  40. cout << s.count ( 2 ) << endl; /// 1
  41. cout << s.count ( 4 ) << endl; /// 0
  42.  
  43.  
  44. /// Front element in set
  45. cout << *s.begin() << endl; /// 1
  46.  
  47. /// Last element in set
  48. cout << *(--s.end()) << endl; /// 3
  49. cout << *s.rbegin() << endl; /// 3
  50.  
  51.  
  52. /// Erase an element;
  53.  
  54. s = { 1, 2, 3, 4, 5, 6 };
  55.  
  56. s.erase ( 2 );
  57. cout << s.size() << endl; /// 5
  58. for ( auto u : s ) cout << u << " "; /// 1 3 4 5 6
  59. cout << endl;
  60.  
  61. s.erase ( 10 );
  62. cout << s.size() << endl; /// 5
  63. for ( auto u : s ) cout << u << " "; /// 1 3 4 5 6
  64. cout << endl;
  65.  
  66.  
  67. /// Erasing front element in set
  68.  
  69. s = { 1, 2, 3, 4, 5, 6 };
  70.  
  71. s.erase ( s.begin() );
  72. cout << s.size() << endl; /// 5
  73. for ( auto u : s ) cout << u << " "; /// 2 3 4 5 6
  74. cout << endl;
  75.  
  76. /// Erasing back element in set
  77.  
  78. s = { 1, 2, 3, 4, 5, 6 };
  79.  
  80. s.erase ( --s.end() );
  81. cout << s.size() << endl; /// 5
  82. for ( auto u : s ) cout << u << " "; /// 1 2 3 4 5
  83. cout << endl;
  84.  
  85.  
  86. /// set of pair
  87. set<pair<int, int>> s1;
  88.  
  89. s1.insert ( { 1, 2 } );
  90. s1.insert ( { 1, 2 } );
  91. s1.insert ( { 4, 2 } );
  92. s1.insert ( { 4, 3 } );
  93. s1.insert ( { 2, 2 } );
  94. s1.insert ( { 2, 1 } );
  95.  
  96. /**
  97.  
  98. Output :
  99.  
  100. 5
  101. 1 2
  102. 2 1
  103. 2 2
  104. 4 2
  105. 4 3
  106.  
  107. */
  108.  
  109. cout << s1.size() << endl;
  110. for ( auto u : s1 ) cout << u.first << " " << u.second << endl;
  111.  
  112. /// Set of string
  113.  
  114. set<string> s2;
  115.  
  116. s2.insert ( "momo" );
  117. s2.insert ( "momo" );
  118. s2.insert ( "prety" );
  119. s2.insert ( "prety" );
  120. s2.insert ( "shahriar" );
  121. s2.insert ( "nobel" );
  122. s2.insert ( "sharif" );
  123. s2.insert ( "proma" );
  124.  
  125. cout << s2.size() << endl;
  126. for ( auto u : s2 ) cout << u << endl;
  127.  
  128. /**
  129.  
  130. Output :
  131.  
  132. 6
  133. momo
  134. nobel
  135. prety
  136. proma
  137. shahriar
  138. sharif
  139.  
  140. */
  141.  
  142. /// set in discanding order
  143. set<int, greater<int>> s3 = {3, 4, 1, 2};
  144. for ( auto u : s3 ) cout << u << " "; /// 4 3 2 1
  145. cout << endl;
  146.  
  147.  
  148. set<string, greater<string>> s4;
  149.  
  150. s4.insert ( "momo" );
  151. s4.insert ( "momo" );
  152. s4.insert ( "prety" );
  153. s4.insert ( "prety" );
  154. s4.insert ( "shahriar" );
  155. s4.insert ( "nobel" );
  156. s4.insert ( "sharif" );
  157. s4.insert ( "proma" );
  158.  
  159. cout << s4.size() << endl;
  160. for ( auto u : s4 ) cout << u << endl;
  161.  
  162. /**
  163. Output :
  164.  
  165. 6
  166. sharif
  167. shahriar
  168. proma
  169. prety
  170. nobel
  171. momo
  172.  
  173. */
  174.  
  175. set<pair<int, int>, greater<pair<int,int>>> s5;
  176.  
  177. s5.insert ( { 1, 2 } );
  178. s5.insert ( { 1, 2 } );
  179. s5.insert ( { 4, 2 } );
  180. s5.insert ( { 4, 3 } );
  181. s5.insert ( { 2, 2 } );
  182. s5.insert ( { 2, 1 } );
  183.  
  184.  
  185. cout << s5.size() << endl;
  186. for ( auto u : s5 ) cout << u.first << " " << u.second << endl;
  187.  
  188. /**
  189.  
  190. Output :
  191. 5
  192. 4 3
  193. 4 2
  194. 2 2
  195. 2 1
  196. 1 2
  197.  
  198. */
  199.  
  200.  
  201. return 0;
  202. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement