【C++】程序题( STL标准模板库)

简介: 【C++】程序题( STL标准模板库)

🎯程序一:

定义包含5个元素的整型数组,从键盘输入数据对数组进行赋值;使用sort排序函数对数据按从大到小的顺序排序并输出排序后的数组。


#include  万能头文件


#include


sort(a,a+5,greater());  //降序


sort(a,a+5,less());   //升序


03c18b60d9166360d864ec58af111038_30fcad6b903f3f2486352a46dac89350.png


🎯程序二:

创建整型数据的vector可变长数组,向vector尾部插入数据98,34,56,78,23;使用迭代器输出vector,插入值58到第3个位置,删除最后一个元素后输出vector;使用sort函数对数组进行从小到大排序并输出;使用reverse方法将元素翻转并输出。


元素翻转函数:reverse(v.begin(),v.end());


注意:每行数据输出后有一个半角空格。


34d4c680980e5357d8b48fa465d96683_dc55a508195dcf015d50164e076dd028.png


🎯程序三:

创建整型数据的List实现双向链表,向链表头部依次插入数据34,56,78;向链表尾部依次插入数据23,98,99;使用迭代器输出链表,输出链表的最大值,删除数值98;使用sort函数对数组进行从小到大排序并输出。


    List排序函数:list.sort();


    注意:第一、三行数据输出后有一个半角空格。


 

6019a34f2b23ce75da0452881bdd577c_99bed4843c4b936ba6906f483f1af69f.png



🎯程序四:

创建整型数据set集合,向set依次插入数据23,56,18,23,79,56;使用迭代器输出set集合的数据并观察结果;查找集合中是否存在值56和99;删除集合第一个元素并插入数值88后输出数据。


注意:集合数据输出后有一个半角空格。


f75e95150b7364c29f828934e279e8c3_0a0ff97adcf823d9eea40ae4b09a3083.png


🎯程序五:

使用map容器对数字10~15映射英文单词A~F,并在控制台输出。


de3f10373a2960ae8a4065082b0a4235_5664304df0ca0a8f6e4929ddc58ebe8c.png


🎯答案一:

#include <bits/stdc++.h>
 
using namespace std;
 
int main(){
 
int a[5],i;
 
for(i=0;i<5;i++)
 
  cin>>a[i];
 
sort(a,a+5,greater<int>());
 
for(i=0;i<5;i++)
 
  cout<<a[i]<<" ";
 
cout<<endl;
 
return 0;
 
}
 
 
 


🎯答案二:

#include <bits/stdc++.h>
 
using namespace std;
 
int main() {
 
  vector<int> v;
 
  vector<int>::iterator pos;
 
  v.push_back(98);
 
  v.push_back(34);
 
  v.push_back(56);
 
  v.push_back(78);
 
  v.push_back(23);
 
  for(pos=v.begin(); pos!=v.end(); ++pos)
 
    cout<<*pos<<" ";
 
  cout<<endl;
 
  v.insert(v.begin()+2,58);
 
  v.erase(v.end()-1);
 
  for(pos=v.begin(); pos!=v.end(); ++pos)
 
    cout<<*pos<<" ";
 
  cout<<endl;
 
  sort(v.begin(),v.end());
 
  for(pos=v.begin(); pos!=v.end(); ++pos)
 
    cout<<*pos<<" ";
 
  cout<<endl;
 
  reverse(v.begin(),v.end());
 
  for(pos=v.begin(); pos!=v.end(); ++pos)
 
    cout<<*pos<<" ";
 
  cout<<endl;
 
  return 0;
 
}
 
 
 


🎯答案三:

#include <bits/stdc++.h>
 
using namespace std;
 
int main() {
 
list<int> lt;
 
list<int>::iterator it;
 
lt.push_front(34);
 
lt.push_front(56);
 
lt.push_front(78);
 
lt.push_back(23);
 
lt.push_back(98);
 
lt.push_back(99);
 
int max=*(lt.begin());
 
for(it=lt.begin(); it!=lt.end(); it++) {
 
if(max<*it)
 
max=*it;
 
cout<<*it<<" ";
 
}
 
cout<<endl;
 
cout<<"max="<<max<<endl;
 
lt.remove(98);
 
lt.sort();
 
for(it=lt.begin(); it!=lt.end(); it++)
 
cout<<*it<<" ";
 
cout<<endl;
 
return 0;
 
}
 
 
 


🎯答案四:

#include <bits/stdc++.h>
 
using namespace std;
 
int main() {
 
  set<int> s;
 
  set<int>::iterator pos;
 
  s.insert(23);
 
  s.insert(56);
 
  s.insert(18);
 
  s.insert(23);
 
  s.insert(79);
 
  s.insert(56);
 
  for(pos=s.begin();pos!=s.end();pos++)
 
     cout<<*pos<<" ";
 
  cout<<endl;
 
    cout<<"是否存在56:"<<s.count(56)<<endl;
 
    cout<<"是否存在99:"<<s.count(99)<<endl;
 
    s.erase(s.begin());
 
    s.insert(88);
 
    for(pos=s.begin();pos!=s.end();pos++)
 
     cout<<*pos<<" ";
 
  cout<<endl;
 
  return 0;
 
}
 
 
 

🎯答案五:

#include <bits/stdc++.h>
 
using namespace std;
 
int main() {
 
  map<int,char> m;
 
  for(int i=10;i<=15;i++)
 
     m[i]=65+i-10;
 
  for(int i=10;i<=15;i++)
 
     cout<<i<<"->"<<m[i]<<endl;
 
  return 0;
 
}
相关文章
|
1月前
|
算法 C++ 容器
C++标准库(速查)总结
C++标准库(速查)总结
61 6
|
1月前
|
存储 程序员 C++
C++常用基础知识—STL库(2)
C++常用基础知识—STL库(2)
68 5
|
30天前
|
编译器 程序员 C++
【C++打怪之路Lv7】-- 模板初阶
【C++打怪之路Lv7】-- 模板初阶
16 1
|
1月前
|
存储 自然语言处理 程序员
C++常用基础知识—STL库(1)
C++常用基础知识—STL库(1)
52 1
|
1月前
|
算法 数据处理 C++
c++ STL划分算法;partition()、partition_copy()、stable_partition()、partition_point()详解
这些算法是C++ STL中处理和组织数据的强大工具,能够高效地实现复杂的数据处理逻辑。理解它们的差异和应用场景,将有助于编写更加高效和清晰的C++代码。
22 0
|
6天前
|
存储 编译器 C++
【c++】类和对象(中)(构造函数、析构函数、拷贝构造、赋值重载)
本文深入探讨了C++类的默认成员函数,包括构造函数、析构函数、拷贝构造函数和赋值重载。构造函数用于对象的初始化,析构函数用于对象销毁时的资源清理,拷贝构造函数用于对象的拷贝,赋值重载用于已存在对象的赋值。文章详细介绍了每个函数的特点、使用方法及注意事项,并提供了代码示例。这些默认成员函数确保了资源的正确管理和对象状态的维护。
32 4
|
8天前
|
存储 编译器 Linux
【c++】类和对象(上)(类的定义格式、访问限定符、类域、类的实例化、对象的内存大小、this指针)
本文介绍了C++中的类和对象,包括类的概念、定义格式、访问限定符、类域、对象的创建及内存大小、以及this指针。通过示例代码详细解释了类的定义、成员函数和成员变量的作用,以及如何使用访问限定符控制成员的访问权限。此外,还讨论了对象的内存分配规则和this指针的使用场景,帮助读者深入理解面向对象编程的核心概念。
27 4
|
30天前
|
存储 编译器 对象存储
【C++打怪之路Lv5】-- 类和对象(下)
【C++打怪之路Lv5】-- 类和对象(下)
27 4
|
30天前
|
编译器 C语言 C++
【C++打怪之路Lv4】-- 类和对象(中)
【C++打怪之路Lv4】-- 类和对象(中)
23 4
|
30天前
|
存储 安全 C++
【C++打怪之路Lv8】-- string类
【C++打怪之路Lv8】-- string类
21 1