2015级C++第15周程序阅读 范型程序设计

简介: 阅读下面的程序,对照运行结果,领会STL的用法 (1)#include <string>#include <set>#include <iterator>#include <iostream>using namespace std;int main(){ set <string> str

阅读下面的程序,对照运行结果,领会STL的用法
(1)

#include <string>
#include <set>
#include <iterator>
#include <iostream>
using namespace std;
int main()
{
    set <string> strset;
    strset.insert("cantaloupes");
    strset.insert("grapes");
    strset.insert("apple");
    strset.insert("orange");
    strset.insert("banana");
    strset.insert("grapes");
    copy(strset.begin(), strset.end(), ostream_iterator<string>(cout, " "));
    cout << endl;
    return 0;
}

(2)

#include <functional>
#include <numeric>
#include <vector>
#include <iostream>
using namespace std;
int main()
{
    vector<int> v(5);
    for (int i = 0; i < 5; i++)
        v[i] = i + 1;
    int sum = accumulate(v.begin(), v.end(), 0);
    cout << "Sum of values == " << sum << endl;
    int product = accumulate(v.begin(), v.end(), 1, multiplies<long>());
    cout << "Product of values == " << product << endl;
    return 0;
}

(3)

#include <algorithm>
#include <functional>
#include <vector>
#include <iostream>
#include <numeric>
#include <iterator>
using namespace std;
int main()
{
    int a[] = {1,4,7,2,5,8};
    int b[] = {1,2,3,3,2,1};
    const int ASZ = sizeof a / sizeof a[0];
    const int BSZ = sizeof b / sizeof b[0];
    ostream_iterator<int> out(cout,"  ");
    copy(a, a + ASZ, out);
    cout<<endl;
    copy(b, b + BSZ, out);
    cout<<endl;
    int r = accumulate(a, a + ASZ, 0);
    cout << "accumulate 1: " << r << endl;
    // Should produce the same result:
    r = accumulate(b, b + BSZ, 0, plus<int>());
    cout << "accumulate 2: " << r << endl;
    r = inner_product(a, a + ASZ, b, 0);
    // 或  r = inner_product(a, a + ASZ, b, 0, plus<int>(), multiplies<int>());
    cout << "inner_product : " << r << endl;
    int* it = partial_sum(a, a + ASZ, b);
    // 或 int* it = partial_sum(a, a + ASZ, b, plus<int>());
    copy(b, it, out);
    cout<<endl;
    it = adjacent_difference(a, a + ASZ, b);
    // 或 it = adjacent_difference(a, a + ASZ, b, minus<int>());
    copy(b, it, out);
    cout<<endl;
    return 0;
}

(4)

#include <algorithm>
#include <functional>
#include <iostream>
#include <vector>
#include <iterator>
using namespace std;
class myAdd: public binary_function<int,int,int>
{
public:
    int operator()(int a, int b) const
    {
        return a+b;
    }
};
int main()
{
    int a[5]= {1,2,3,4,5};
    vector<int> my(5);
    transform(a,a+5,my.begin(), bind2nd(myAdd(), 4));
    copy(my.begin(), my.end(), ostream_iterator<int>(cout, " "));
    cout<<endl;
    transform(a,a+5,a,my.begin(), myAdd());
    copy(my.begin(), my.end(), ostream_iterator<int>(cout, " "));
    cout<<endl;
    return 0;
}

(5)

#include <iterator>
#include <algorithm>
#include <functional>
#include <iostream>
#include <vector>
using namespace std;
class Angle
{
    int degrees;
public:
    Angle(int deg) : degrees(deg) {}
    int mul(int times)
    {
        return degrees *= times;
    }
};
int main()
{
    int x[] = {1, 2, 4, 5, 8};
    vector<Angle> va;
    for(int i =10; i <= 50; i += 10)
        va.push_back(Angle(i));
    transform(va.begin(), va.end(), x, ostream_iterator<int>(cout , "  "), mem_fun_ref(&Angle::mul));
    cout << endl;
    return 0;
}

(6)

#include <string>
#include <iostream>
#include <map>
using namespace std;
class CStudent
{
public :
    int nStudentID;
    int nAge;
public :
    CStudent()  {  }
    CStudent(int nSID, int nA)
    {
        nStudentID=nSID;
        nAge=nA;
    }
    //复制构造函数
    CStudent(const CStudent& ob) 
    {
        nStudentID=ob.nStudentID;
        nAge=ob.nAge;
    }
};
int main()
{
    map <string, CStudent> mapStudent;
    mapStudent["zhangsan"] = CStudent(100012, 22);
    mapStudent["Lisi"] = CStudent(100085, 21);
    mapStudent["Wangwu"] = CStudent(100093, 23);
    cout << "The Student number for Lisi  is " <<(mapStudent["Lisi"].nStudentID) << endl;
    return 0;
}
目录
相关文章
|
23天前
|
存储 缓存 算法
【C/C++ 性能优化】提高C++程序的缓存命中率以优化性能
【C/C++ 性能优化】提高C++程序的缓存命中率以优化性能
111 0
|
18天前
|
存储 缓存 C++
C++链表常用的函数编写(增查删改)内附完整程序
C++链表常用的函数编写(增查删改)内附完整程序
|
30天前
|
缓存 编译器 程序员
C/C++编译器并行优化技术:并行优化针对多核处理器和多线程环境进行优化,以提高程序的并行度
C/C++编译器并行优化技术:并行优化针对多核处理器和多线程环境进行优化,以提高程序的并行度
60 0
|
30天前
|
缓存 编译器 程序员
C/C++编译器全局优化技术:全局优化是针对整个程序进行的优化,包括函数之间的优化
C/C++编译器全局优化技术:全局优化是针对整个程序进行的优化,包括函数之间的优化
25 0
|
30天前
|
缓存 算法 编译器
C/C++编译器内存优化技术:内存优化关注程序对内存的访问和使用,以提高内存访问速度和减少内存占用。
C/C++编译器内存优化技术:内存优化关注程序对内存的访问和使用,以提高内存访问速度和减少内存占用。
36 0
|
1月前
|
自然语言处理 编译器 调度
深入gcc编译器:C/C++代码如何变为可执行程序
深入gcc编译器:C/C++代码如何变为可执行程序
75 0
|
1月前
|
并行计算 安全 编译器
【C/C++ 编译相关 gcc】一次搞懂GCC编译选项:优化代码、调试程序必备!
【C/C++ 编译相关 gcc】一次搞懂GCC编译选项:优化代码、调试程序必备!
33 0
|
22天前
|
存储 C++ 容器
C++入门指南:string类文档详细解析(非常经典,建议收藏)
C++入门指南:string类文档详细解析(非常经典,建议收藏)
31 0
存储 编译器 Linux
18 0
|
2天前
|
编译器 C++
标准库中的string类(上)——“C++”
标准库中的string类(上)——“C++”