CPP_mapの使い方 の変更点 - アールメカブ

アールメカブ


CPP_mapの使い方 の変更点


[[Programming]]

 #include <iostream>
 #include <fstream>
 #include <string>
 #include <map>
 #include <vector>
 #include <ctime>
 #include <functional>
 #include <algorithm>
 #include <boost/random.hpp>
 // 「メルセンヌツイスター」( Seed=現在時刻 ) で
 // 「小さな整数の一様乱数」( 1〜6 ) を生成
 
 using namespace std;
 
 // 柏原基礎知識実践編 p.74
 
 class Random
 {
 public:
  // コンストラクタ
  Random(){ srand( (unsigned int)time(NULL) ); }
  
  unsigned int operator()(unsigned int max)
  {
    double tmp = static_cast<double>( rand() ) / 
           static_cast<double>( RAND_MAX );
    return static_cast<unsigned int>( tmp * max );
  }
  
 };
 
 
 int main(){
  string filename = "file.cpp.test";
  string str;
  vector<string> v;
  map<string, int> m1;
  map<string, int>::iterator pa;
 // pair<string, int> p;
  
  ifstream ifs(filename.c_str());// ファイルを開き
  if(!ifs){
    cout << "cant find file" << endl;
  }
  else{
    cout << "find file" << endl;
    while(!ifs.eof()){
      ifs >> str;
      v.push_back(str);//すべての行をベクトルに代入
      cout << str << endl;
    }
  }
  cout << "ランダム化の実行" << endl;
  Random r;
  random_shuffle(v.begin(), v.end(), r);
  cout << "ランダム後の表示" << endl;
  for(int i = 0; i < v.size(); i++){
    cout << v[i] << endl;
  }
  
  cout << "map への登録" << endl;
  for(int i = 0; i < v.size(); i++){
//cout << v[i] << endl;
//    if( (m1.find(v[i]))->second > 0){
  if( (pa = m1.find(v[i])) != m1.end()){
  //すでにマップにあるのなら
//      cout << "find" << endl;
//      (m1.find(v[i]))->second = ( (m1.find(v[i]))->second) +1;
       pa->second = pa->second + 1;
      //二つ目の数値を加算
    }
    else{// そうでないなら,データを挿入
//      p.first = v[i];
//      p.second = 1;
      m1.insert(make_pair(v[i], 1);
      m1.insert(make_pair(v[i], 1) );
//	cout << "find " << endl;
    }
  }
   // map の要素すべてにアクセスする
   cout << "map の内容の表示" << endl;
//  map<string, int>::iterator itr;
  pa = m1.begin();
  int n = (int)m1.size();
  
  for (int i = 0; i < n; i++) {
    cout << pa->first << " " << pa->second << endl;
    pa++;
  }
  
 }