zoukankan      html  css  js  c++  java
  • UVA 101 vector

     题目链接

     白书上的例题,关于vector的使用。不定长数组vector,类型内部封装了一些常用操作。vector就像一个二维数组,只有第一维的大小是固定的,可以像数组一样访问到其中的每一个元素。

    vector<int> v; 常用操作  v.size();  v.clear();清空 v.resize();改变大小  v.push_back();在尾部添加元素  v.pop_back();在尾部删除元素  v.empty();检测是否为空 

    vector之间可直接赋值或作为函数的返回值,像是“一等公民”一样。

    注意事项:1.读题时提取指令间的共同点,减少重复代码。 2.代码中用到引用

    find_block(a,pa,ha);
    void find_block(int a ,int& p ,int& h ) {
        for(int p = 0; p < n; p++) {
            for(int h = 0; h < pile[p].size() ; h++) {
                if(pile[p][h]==a) return;        
            }    
        } 
    }
    #include<iostream>
    #include<cstdio>
    #include<vector>
    #include<string>
    using namespace std;
    #define MAXN 30
    int n;
    string s1,s2;
    vector<int>  pile[MAXN]; 
    
    //以引用的形式返回调用者 
    void find_block(int a ,int& p ,int& h ) {
        for(p = 0; p < n; p++) {
            for(h = 0; h < pile[p].size() ; h++) {
                if(pile[p][h]==a) return;        
            }    
        } 
    }
    
    void clear_above(int p,int h) {
        for(int i = h+1;i < pile[p].size();i++) {
            int k = pile[p][i];
            pile[k].push_back(k);
        }
        pile[p].resize(h+1);    
    }
    
    //把第p堆高度为h及其上方的木块整体移动到p2堆顶部 
    void pile_onto(int p,int h,int p2) {
        for(int i=h;i<pile[p].size();i++) {
            pile[p2].push_back(pile[p][i]);
        }
        pile[p].resize(h);
        
    }
    int main() {
        int a,b;
        while(cin>>n) {
            for(int i=0;i<n;i++) {
                pile[i].push_back(i);    
            }
            int pa,ha,pb,hb;
            while(cin>>s1) {
            
                if(s1=="quit") break;
                cin>>a>>s2>>b;    
                find_block(a,pa,ha);
                find_block(b,pb,hb);    
                if(pa==pb) continue;
                
                if(s2=="onto") {
                    clear_above(pb,hb); 
                } 
                if(s1=="move") {
                    clear_above(pa,ha);
                }
                pile_onto(pa,ha,pb);
            }
        
            for(int i=0;i<n;i++) {
                printf("%d:",i);
                for(int j=0;j<pile[i].size();j++) {
                    printf(" %d",pile[i][j]);
                }
                printf("
    ");
            }
        }
        
        
        return 0;
    }
    View Code

    Vector成员函数

    函数

    表述

    c.assign(beg,end)

    c.assign(n,elem)

    将[beg; end)区间中的数据赋值给c。

    将n个elem的拷贝赋值给c。

    c.at(idx)

    传回索引idx所指的数据,如果idx越界,抛出out_of_range。

    c.back()

    传回最后一个数据,不检查这个数据是否存在。

    c.begin()

    传回迭代器重的可一个数据。

    c.capacity()

    返回容器中数据个数。

    c.clear()

    移除容器中所有数据。

    c.empty()

    判断容器是否为空。

    c.end()

    指向迭代器中的最后一个数据地址。

    c.erase(pos)

    c.erase(beg,end)

    删除pos位置的数据,传回下一个数据的位置。

    删除[beg,end)区间的数据,传回下一个数据的位置。

    c.front()

    传回第一个数据。

    get_allocator

    使用构造函数返回一个拷贝。

    c.insert(pos,elem)

    c.insert(pos,n,elem)

    c.insert(pos,beg,end)

    在pos位置插入一个elem拷贝,传回新数据位置。

    在pos位置插入n个elem数据。无返回值。

    在pos位置插入在[beg,end)区间的数据。无返回值。

    c.max_size()

    返回容器中最大数据的数量。

    c.pop_back()

    删除最后一个数据。

    c.push_back(elem)

    在尾部加入一个数据。

    c.rbegin()

    传回一个逆向队列的第一个数据。

    c.rend()

    传回一个逆向队列的最后一个数据的下一个位置。

    c.resize(num)

    重新指定队列的长度。

    c.reserve()

    保留适当的容量。

    c.size()

    返回容器中实际数据的个数。

    c1.swap(c2)

    swap(c1,c2)

    将c1和c2元素互换。

    同上操作。

    vector<Elem> c

    vector <Elem> c1(c2)

    vector <Elem> c(n)

    vector <Elem> c(n, elem)

    vector <Elem> c(beg,end)

    c.~ vector <Elem>()

    创建一个空的vector。

    复制一个vector。

    创建一个vector,含有n个数据,数据均已缺省构造产生。

    创建一个含有n个elem拷贝的vector。

    创建一个以[beg;end)区间的vector。

    销毁所有数据,释放内存。

  • 相关阅读:
    nrm安装与配置
    vue-cli2升级到webpack4
    npm和yarn的区别
    Vite和Vue CLI的优劣
    基于vue+element+select实现的自定义控件selectTree
    Extjs 隐藏tabpanel的header / title
    await/async 总结
    泛型
    jpg图片打包生成pdf文件的几种方式
    varchar(100)和varchar(10)的区别
  • 原文地址:https://www.cnblogs.com/LinesYao/p/5459753.html
Copyright © 2011-2022 走看看