首页 > 其他 > 详细

OpenMP

时间:2014-06-21 09:08:04      阅读:410      评论:0      收藏:0      [点我收藏+]

OpenMP中一个变量可以有三种类型,即shared、private和reduction,默认为shared,除非如下三种特别情况:

一、在并行for循环中紧临parallel for 语句的循环变量是私有的;

二、并行区域代码块里的声明的变量是私有的;

三、所有通过private,firstprivate,lastprivate和reduction子句声明的变量为私有变量。

 

#include <iostream>
#include <fstream>
#include <map>
#include <string>
#include <sstream>
#include <vector>

using namespace std;

int main(int argc, char *argv[])
{
  ifstream ifs(argv[1]);
  string name;
  map<string, int> brands;
  while (!ifs.eof()) {
    getline(ifs, name);
    map<string, int>::const_iterator it = brands.find(name);
    if (it == brands.end()) {
      brands[name] = 1;
    } else {
      brands[name] = it->second + 1;
    }
  }

  vector<string> names;
  map<string, int>::const_iterator it;
  for (it = brands.begin(); it != brands.end(); ++it) {
    names.push_back(it->first);
  }
  vector<int> counts(names.size());

#pragma omp parallel
{
  int i;
  #pragma omp for
  for (i = 0; i < names.size(); ++i) {
    int count = 0;
    map<string, int>::const_iterator it2;
    for (it2 = brands.begin(); it2 != brands.end(); ++it2) {
      string name = it2->first;
      if (name.find(names[i]) != string::npos) {
        count += it2->second;
      }
    }

    counts[i] = count;
  }
}

  for (int i = 0; i < names.size(); ++i) {
    cout << names[i] << "\t" << counts[i] << endl;
  }
  
  return 0;
}

 

OpenMP,布布扣,bubuko.com

OpenMP

原文:http://www.cnblogs.com/agnostic/p/3795107.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!