zoukankan      html  css  js  c++  java
  • C++与STL

      从C到C++, 这篇博客不糊弄了,认认真真写吧!很多内容来自刘汝佳的《算法竞赛入门经典》,这本紫书真的好用,感谢作者刘汝佳。

      首先,需要弄清楚C与C++之间的区别,C语言相对于C++来说是更加基本的,用C写代码会比C++多写一些,自然调试的难度也会增加,C++相比于C有着更加强大的功能,当然如果我们不能够

    灵活透彻的掌握C++的特性时候在必要情况下只能用基本的代码来写了,感觉用C++不是一件容易的事情,很多新的功能必须要更加了解才行。

      C++与C在语法上是不同的,大部分头文件C++的是以'c'大头,而C是以'.h'结尾的,但是C++仍然支持用C的头文件来写,另外它们的输入输出有了明显的区别,cin、cout与scanf、printf相比较简洁了很多,但就是因为这种简洁(不需要声明数据类型)所以导致了速度变慢,用ios::sync_with_stdio(false)可以有效加速流,C++比C多了bool使得判断更加清晰。

      C++的引用也是要说明的, 下面是代码:

    #include <iostream> 
    using namespace std; 
    
    void swap2(int& a1, int& b1) {
        int t = a1; a1 = b1; b1 = t;     
    }
    
    int main() {
        int a = 3, b = 4; 
        swap2(a, b); 
        cout << a << "
    " << b;
        return 0;    
    }

    用'&'符号来引用,其中引用与指针是十分相似的,具体的区别我也不太能够说明,但是引用是两个参数共同用一个地址,所以一个参数改变,另一个参数所对应的值也是会改变的,用引用有什么

    好处呢?引用可以节省空间时间的浪费,因为引用也是用地址嘛,在某种条件下引用传递的数据小,自然速度也快(地址4字节),但不是任何条件下都要使用引用的。

      下面就说一说结构体吧,结构体很重要,它不仅能够包含变量(成员变量)还可以包含函数(成员函数)当成员函数的名称与结构体名称相同时,我们就叫它构造函数,对于构造函数我的认识仍然不够啊!不过我知道,构造函数能够在声明结构体类型时让改变成员变量的大小,举个例子:

    struct Point { 
        int x, y; 
        Point(int x=0; int y=0) : x(x), y(y) {}
    };

    结构体Point里面的函数就叫结构函数,其中的x(x)与y(y)就是this->x = x this->y = y还可以写成(*this.x = x)(前面的x, y时成员变量,不是结构函数里面的东西),这就达到了修改成员函数的目的了。

      说完结构体,我们说一说模板吧!首先我们给出两个代码:

    int sum(int* begin, int* end) {
        int ans = 0; 
        for(int *a = begin; a != end; a++)
             ans += *a; 
        return ans;
    }
    template<typename T>
    T sum(T* begin, T* end) { T ans = 0; for(T *a = begin; a != end; a++) ans = ans + *a; return ans; }

    int main() {
      double a[] = { ...
      cout << sum(a, ...
      Point b[] = { ...
      cout << sum(b, ...
    }

    其中后面的就支持任意类型的,这就是模板的强大,注意我们在第二个代码时候为什么没有用“+=”二十用了“ans = ans + *a" ? 这是由于我们没有定义Point的‘+=‘运算符,Point的’+‘运算符我没有写,

    在写程序时候应该加上。 算了,我还是写一下吧!

    template<typename T> 
    Point<T> operator + (const Point<T>& A, const Point<T>& b) {
        return Point<T>(A.x+B.x, A.y+B.y); 
    }    

    但是写程序时候还是要调整与修改的,这无关,我们继续往下说。既然模板这么强大,那么sort排序是不是运用到模板了吗,的确,sort支持很多类型,不过在写的时候还是要定义一下'<'运算符。

      说到sort,sort就是STL,那么STL是什么呢?Standard Template Library 标准模板库,这个模板库里有很多东西,我们仅仅说一下几个重要的:set、map、vector、stack、queue、优先队列

    set是集合的意思,它具有“互异性”; map就是从键到值的映射,所以也叫关联数组;与于这两个我们能够提供的操作有.count()、.insert()、.find()、.remove()等等。vector是比较灵活的不定长的”数组“,它可以支持的操作有.size()、.resize()、.push_back()、.pop_back()、.clear()等等,剩下的stack支持.top()、.pop()、.push(),queue支持push pop empty等等,优先队列要将front改为top......

       这些就是C++与STL初级的部分了,剩下的东西明天在说(测试STL、大整数类)。。。

      

      如有问题请联系我,转载请标明出处。

    语言c++计算机程序设计爱好者 不定期更新题目题解 望互相分享心得体会 有意留言加q
  • 相关阅读:
    协作调优
    快速打开你的手机网页
    DB2性能学习笔记V0.1
    IE11将支持SPDY
    Linux性能优化学习笔记V0.1
    memcache学习笔记: http://www.docin.com/p577837919.html
    LoadRunner 测试Tuxedo的问题
    《Web测试技术大全》V0.1发布
    .NET性能分析工具 YourKit Profiler 8 for .NET
    《.NET Performance Testing and Optimization》学习笔记
  • 原文地址:https://www.cnblogs.com/yifeiWa/p/10353159.html
Copyright © 2011-2022 走看看