亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sequenceperformance.cpp

?? Thinking in C++ 2.0書籍源碼光盤
?? CPP
字號:
//: C20:SequencePerformance.cpp
// From Thinking in C++, 2nd Edition
// Available at http://www.BruceEckel.com
// (c) Bruce Eckel 1999
// Copyright notice in Copyright.txt
// Comparing the performance of the basic
// sequence containers for various operations
#include <vector>
#include <queue>
#include <list>
#include <iostream>
#include <string>
#include <typeinfo>
#include <ctime>
#include <cstdlib>
using namespace std;

class FixedSize {
  int x[20];
  // Automatic generation of default constructor,
  // copy-constructor and operator=
} fs;

template<class Cont>
struct InsertBack {
  void operator()(Cont& c, long count) {
    for(long i = 0; i < count; i++)
      c.push_back(fs);
  }
  char* testName() { return "InsertBack"; }
};

template<class Cont>
struct InsertFront {
  void operator()(Cont& c, long count) {
    long cnt = count * 10;
    for(long i = 0; i < cnt; i++)
      c.push_front(fs);
  }  
  char* testName() { return "InsertFront"; }
};

template<class Cont>
struct InsertMiddle {
  void operator()(Cont& c, long count) {
    typename Cont::iterator it;
    long cnt = count / 10;
    for(long i = 0; i < cnt; i++) {
      // Must get the iterator every time to keep
      // from causing an access violation with
      // vector. Increment it to put it in the
      // middle of the container:
      it = c.begin();
      it++;
      c.insert(it, fs);
    }
  }
  char* testName() { return "InsertMiddle"; }
};

template<class Cont>
struct RandomAccess { // Not for list
  void operator()(Cont& c, long count) {
    int sz = c.size();
    long cnt = count * 100;
    for(long i = 0; i < cnt; i++)
      c[rand() % sz];
  }
  char* testName() { return "RandomAccess"; }
};

template<class Cont>
struct Traversal {
  void operator()(Cont& c, long count) {
    long cnt = count / 100;
    for(long i = 0; i < cnt; i++) {
      typename Cont::iterator it = c.begin(),
        end = c.end();
      while(it != end) it++;
    }
  }
  char* testName() { return "Traversal"; }
};

template<class Cont>
struct Swap {
  void operator()(Cont& c, long count) {
    int middle = c.size() / 2;
    typename Cont::iterator it = c.begin(), 
      mid = c.begin();
    it++; // Put it in the middle
    for(int x = 0; x < middle + 1; x++)
      mid++;
    long cnt = count * 10;
    for(long i = 0; i < cnt; i++)
      swap(*it, *mid);
  }
  char* testName() { return "Swap"; }
};

template<class Cont>
struct RemoveMiddle {
  void operator()(Cont& c, long count) {
    long cnt = count / 10;
    if(cnt > c.size()) {
      cout << "RemoveMiddle: not enough elements"
        << endl;
      return;
    }
    for(long i = 0; i < cnt; i++) {
      typename Cont::iterator it = c.begin();
      it++;
      c.erase(it);
    }
  }
  char* testName() { return "RemoveMiddle"; }
};

template<class Cont>
struct RemoveBack {
  void operator()(Cont& c, long count) {
    long cnt = count * 10;
    if(cnt > c.size()) {
      cout << "RemoveBack: not enough elements"
        << endl;
      return;
    }
    for(long i = 0; i < cnt; i++)
      c.pop_back();
  }
  char* testName() { return "RemoveBack"; }
};

template<class Op, class Container>
void measureTime(Op f, Container& c, long count){
  string id(typeid(f).name());
  bool Deque = id.find("deque") != string::npos;
  bool List = id.find("list") != string::npos;
  bool Vector = id.find("vector") !=string::npos;
  string cont = Deque ? "deque" : List ? "list" 
    : Vector? "vector" : "unknown";
  cout << f.testName() << " for " << cont << ": ";
  // Standard C library CPU ticks:
  clock_t ticks = clock();
  f(c, count); // Run the test
  ticks = clock() - ticks;
  cout << ticks << endl;
}

typedef deque<FixedSize> DF;
typedef list<FixedSize> LF;
typedef vector<FixedSize> VF;

int main(int argc, char* argv[]) {
  srand(time(0));
  long count = 1000;
  if(argc >= 2) count = atoi(argv[1]);
  DF deq;
  LF lst;
  VF vec, vecres;
  vecres.reserve(count); // Preallocate storage
  measureTime(InsertBack<VF>(), vec, count);
  measureTime(InsertBack<VF>(), vecres, count);
  measureTime(InsertBack<DF>(), deq, count);
  measureTime(InsertBack<LF>(), lst, count);
  // Can't push_front() with a vector:
//! measureTime(InsertFront<VF>(), vec, count);
  measureTime(InsertFront<DF>(), deq, count);
  measureTime(InsertFront<LF>(), lst, count);
  measureTime(InsertMiddle<VF>(), vec, count);
  measureTime(InsertMiddle<DF>(), deq, count);
  measureTime(InsertMiddle<LF>(), lst, count);
  measureTime(RandomAccess<VF>(), vec, count);
  measureTime(RandomAccess<DF>(), deq, count);
  // Can't operator[] with a list:
//! measureTime(RandomAccess<LF>(), lst, count);
  measureTime(Traversal<VF>(), vec, count);
  measureTime(Traversal<DF>(), deq, count);
  measureTime(Traversal<LF>(), lst, count);
  measureTime(Swap<VF>(), vec, count);
  measureTime(Swap<DF>(), deq, count);
  measureTime(Swap<LF>(), lst, count);
  measureTime(RemoveMiddle<VF>(), vec, count);
  measureTime(RemoveMiddle<DF>(), deq, count);
  measureTime(RemoveMiddle<LF>(), lst, count);
  vec.resize(vec.size() * 10); // Make it bigger
  measureTime(RemoveBack<VF>(), vec, count);
  measureTime(RemoveBack<DF>(), deq, count);
  measureTime(RemoveBack<LF>(), lst, count);
} ///:~

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本不卡视频在线| 日韩精品久久理论片| 欧美一级日韩免费不卡| 91美女在线视频| 成人福利视频网站| 成人av免费在线| av电影在线观看一区| 色综合天天综合在线视频| 92国产精品观看| 在线观看视频一区| 欧美日韩一区二区电影| 欧美日韩视频在线观看一区二区三区 | 国产精品乱码一区二区三区软件| 精品国产免费视频| 久久久久久久一区| 国产精品福利av| 亚洲午夜激情av| 免费观看成人鲁鲁鲁鲁鲁视频| 毛片av一区二区| 国产激情一区二区三区| jlzzjlzz国产精品久久| 欧美日韩三级在线| 日韩欧美电影一二三| 国产午夜精品理论片a级大结局| 国产精品福利在线播放| 亚洲午夜国产一区99re久久| 欧美aaa在线| 成人免费高清在线观看| 欧美性大战久久| 久久久久高清精品| 亚洲综合在线五月| 国内精品伊人久久久久av一坑| 国产成人av资源| 欧美一区二区视频在线观看| 国产日本亚洲高清| 亚洲成va人在线观看| 国产一区二区免费看| 欧美综合色免费| 国产精品天干天干在观线| 亚洲影视在线观看| 国产98色在线|日韩| 欧美日本国产一区| 中文字幕一区日韩精品欧美| 男女性色大片免费观看一区二区 | 欧美国产日韩精品免费观看| 亚洲国产综合91精品麻豆| 国产精品亚洲一区二区三区妖精| 色噜噜狠狠成人中文综合| 久久伊99综合婷婷久久伊| 午夜欧美在线一二页| 99在线精品免费| 国产欧美一区二区三区网站| 日本美女一区二区| 欧美日韩精品欧美日韩精品一 | 国产真实精品久久二三区| 欧美影院午夜播放| 亚洲天堂网中文字| 成人黄动漫网站免费app| 精品国产一区二区三区忘忧草| 亚洲国产精品嫩草影院| 色综合中文字幕| 亚洲特黄一级片| 国产成人精品aa毛片| 久久精品无码一区二区三区| 蜜桃视频在线观看一区| 在线播放国产精品二区一二区四区| 亚洲私人黄色宅男| www.欧美日韩国产在线| 国产精品麻豆久久久| 成人小视频在线| 中文字幕不卡的av| av亚洲产国偷v产偷v自拍| 国产精品私人自拍| 成人avav在线| 18欧美亚洲精品| 91蜜桃在线观看| 亚洲线精品一区二区三区 | 美日韩黄色大片| 日韩你懂的在线观看| 九九**精品视频免费播放| 日韩欧美国产小视频| 久久精品久久99精品久久| www国产成人免费观看视频 深夜成人网| 日韩av二区在线播放| 久久一日本道色综合| 高清国产一区二区三区| 国产精品不卡在线| 91麻豆国产福利精品| 一区二区三区精品视频| 欧美人与性动xxxx| 天天操天天色综合| 欧美变态tickle挠乳网站| 国产成人精品在线看| 亚洲激情第一区| 日韩一区二区三区视频在线观看| 狠狠狠色丁香婷婷综合久久五月| 欧美激情一区二区三区四区| 91影院在线免费观看| 亚洲欧美日韩国产成人精品影院| 欧美三片在线视频观看| 精品在线亚洲视频| 亚洲欧洲av一区二区三区久久| 色八戒一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久久精品影视| 欧美丝袜丝交足nylons图片| 久久99精品久久久久婷婷| 中文字幕一区二区在线观看| 欧美区一区二区三区| 国产精品456露脸| 亚洲综合免费观看高清完整版在线 | 精品综合久久久久久8888| 国产精品久久久久久久久图文区 | 91小视频在线免费看| 日本亚洲欧美天堂免费| 国产精品网站导航| 欧美一卡在线观看| 色综合欧美在线| 国产在线精品免费| 性欧美疯狂xxxxbbbb| 中文文精品字幕一区二区| 51精品视频一区二区三区| 成人网页在线观看| 日本午夜精品一区二区三区电影| 国产精品毛片大码女人| 精品成人在线观看| 7777精品伊人久久久大香线蕉 | 91精品国产黑色紧身裤美女| av亚洲精华国产精华精华| 久久电影国产免费久久电影 | 日韩天堂在线观看| 色婷婷av一区二区三区gif | 欧美日韩亚州综合| 99久久精品情趣| 国产主播一区二区三区| 麻豆成人综合网| 日韩av二区在线播放| 亚洲成a人片在线观看中文| 亚洲视频你懂的| 中文字幕欧美区| 久久久精品2019中文字幕之3| 日韩色在线观看| 日韩一区二区在线观看视频| 欧美网站一区二区| 欧美系列一区二区| 欧美在线视频日韩| 欧美视频在线观看一区二区| 色屁屁一区二区| 91福利精品视频| 一本到一区二区三区| 99vv1com这只有精品| 成人免费av在线| 99精品视频免费在线观看| 91丨porny丨在线| 色偷偷久久一区二区三区| 日本韩国一区二区三区| 色激情天天射综合网| 欧美三级资源在线| 欧美日韩成人综合在线一区二区| 欧美三日本三级三级在线播放| 欧美色精品在线视频| 在线不卡中文字幕| 精品黑人一区二区三区久久 | 亚洲午夜久久久久| 亚洲一区二区三区四区在线观看| 一区二区三区 在线观看视频| 亚洲曰韩产成在线| 日韩成人av影视| 国产乱码精品一区二区三区五月婷| 国产一区91精品张津瑜| 成人av在线一区二区三区| 99久久久精品| 91精品在线观看入口| 久久久久成人黄色影片| 亚洲天堂福利av| 奇米色一区二区三区四区| 国产精品一区二区视频| 91网站最新网址| 欧美日韩国产另类不卡| 久久九九全国免费| 一区二区视频在线| 免费人成精品欧美精品| 国产91色综合久久免费分享| 欧美综合在线视频| 久久色.com| 亚洲一区二区av在线| 国产在线精品不卡| 欧美日韩高清一区二区不卡| 日韩欧美国产小视频| 亚洲区小说区图片区qvod| 日本在线不卡一区| 91亚洲精华国产精华精华液| 日韩精品一区国产麻豆| 国产精品丝袜久久久久久app| 天天av天天翘天天综合网| 国产精品99久久久久久宅男| 在线免费观看视频一区| 国产色一区二区| 日韩av电影免费观看高清完整版| 99国产精品久|