zoukankan      html  css  js  c++  java
  • fill,fill-n,memset的区别

    这里在网上搜集归纳了一个总结

    • memset函数
      • 按照字节填充某字符
      • 在头文件<string。h>
      • 因为memset函数按照字节填充,所以一般memset只能用来填充char型数组,(因为只有char型占一个字节)如果填充int型数组,除了0和-1,其他的不能。因为只有00000000 = 0,-1同理,如果我们把每一位都填充“1”,会导致变成填充入“11111111”
      • 例如

          int a[20];

           memset(a, 0, sizeof a);
    • fill-n 函数

    fill_n函数的作用是:给你一个起始点,然后再给你一个数值count和val。把从起始点开始依次赋予count个元素val的值。

    注意: 不能在没有元素的空容器上调用fill_n函数
    例题:给你n个数,然后输入一些操作:start,count,paint。表示从start开始连续填充count个数字,paint为填充的数值。
    • fill 函数
      • 按照单元赋值,将一个区间的元素都赋同一个值
      • 在头文件<algorithm>里面
      • fill函数可以赋值任何,而且使用方法特别简便
      • fill(arr, arr + n, 要填入的内容)

    例如:

          int arr[10];

    fill(arr, arr + 10, 2)

    • vector

    在c++中,vector是一个十分有用的容器,下面对这个容器做一下总结。

    1 基本操作

    (1)头文件#include<vector>.

    (2)创建vector对象,vector<int> vec;

    (3)尾部插入数字:vec.push_back(a);

    (4)使用下标访问元素,cout<<vec[0]<<endl;记住下标是从0开始的。

    (5)使用迭代器访问元素.

    vector<int>::iterator it;
    for(it=vec.begin();it!=vec.end();it++)
        cout<<*it<<endl;

    (6)插入元素:    vec.insert(vec.begin()+i,a);在第i+1个元素前面插入a;

    (7)删除元素:    vec.erase(vec.begin()+2);删除第3个元素

    vec.erase(vec.begin()+i,vec.end()+j);删除区间[i,j-1];区间从0开始

    (8)向量大小:vec.size();

    (9)清空:vec.clear();

    vector<int> myvector (8,10);        // myvector: 10 10 10 10 10 10 10 10   

    fill_n (myvector.begin(),4,20);     // myvector: 20 20 20 20 10 10 10 10

    fill_n (myvector.begin()+3,3,33);   // myvector: 20 20 20 33 33 33 10 10 

      vector<int> v{0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
        fill(v.begin(), v.end(), -1);

     

  • 相关阅读:
    【SQL】含有NULL值的排序
    【SQL】结构化查询语言
    【Oracle】体系结构
    【PL/SQL】匿名块、存储过程、函数、触发器
    【Linux】VMware安装VMware Tools工具
    【SQL】INTERVAL YEAR TO MONTH 和 INTERVAL DAY TO SECOND
    Tornado源码浅析
    【Python之路】特别篇--property()函数 和 @property 装饰符
    【Python之路】特别篇--生成器(constructor)、迭代器(iterator)、可迭代对象(iterable)
    【Python之路】特别篇--基于领域驱动模型架构设计的京东用户管理后台
  • 原文地址:https://www.cnblogs.com/carry-2017/p/7198533.html
Copyright © 2011-2022 走看看