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

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

?? prefixspan.cpp

?? 經典的數據關聯挖掘算法prefixspan
?? CPP
字號:
/* PrefixSpan: An efficient algorithm for sequential pattern mining $Id: prefixspan.cpp,v 1.3 2002/01/07 01:30:04 taku-ku Exp $; Copyright (C) 2002 Taku Kudo  All rights reserved. This is free software with ABSOLUTELY NO WARRANTY. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA*/#include <iostream>#include <map>#include <vector>#include <string>#include <string.h>#include <unistd.h>#include <stdlib.h>using namespace std;class string2string {public:   string operator() (const string &str) const { return str; };};class string2int {public:   unsigned int operator() (const string &str) const { return atoi (str.c_str()); };};template <class T = unsigned int, class F = string2int> class PrefixSpan {private:  vector < vector <T> >             transaction;  vector < pair <T, unsigned int> > pattern;  T init;  unsigned int minsup;  unsigned int minpat;  string delimiter;  bool verbose;  ostream *os;  void split (const string &src, 	      const string& key, 	      vector <T>& result)  {    result.clear();    int len =  src.size();    int i = 0; int si = 0;    while(i < len) {      while (i < len && key.find(src[i]) != string::npos) { si++; i++; };      while (i < len && key.find(src[i]) == string::npos) i++;      result.push_back(F()(src.substr(si,i-si)));      si = i;    }  }  void project (T opat, vector <pair <unsigned int, int> > &projected)  {    if (verbose)       cerr << "## projected by pattern [" << opat << "], " 	   << projected.size() << " instances\n";    map <T, vector <pair <unsigned int, int> > > cnt;      for (unsigned int i = 0; i < projected.size(); i++) {      int pos = projected[i].second;      unsigned int id  = projected[i].first;      unsigned int size = transaction[id].size();      map <T, int> tmp;      for (unsigned int j = pos + 1; j < size; j++) {	T item = transaction[id][j];	if (tmp.find (item) == tmp.end()) tmp[item] = j ;      }      for (map <T, int>::iterator k = tmp.begin(); k != tmp.end(); ++k) 	cnt[k->first].push_back (make_pair <unsigned int, int> (id, k->second));    }    if (verbose)       cerr << "## " << cnt.size() << " items found\n";    for (map <T, vector <pair <unsigned int, int> > >::iterator l = cnt.begin (); 	 l != cnt.end (); ) {      if (l->second.size() < minsup) {	map <T, vector <pair <unsigned int, int> > >::iterator tmp = l;	tmp = l;	++tmp;	cnt.erase (l);	l = tmp;      } else {	++l;      }    }    if (verbose)       cerr << "## pruned to " << cnt.size() << " items found\n";    if (cnt.size () == 0) {       if (minpat <= pattern.size()) {	  for (unsigned int i = 0; i < pattern.size(); i++)	    *os << (i ? " " : "") << pattern[i].first << delimiter << pattern[i].second;	  *os << endl;       }      return;    }    for (map <T, vector <pair <unsigned int, int> > >::iterator l = cnt.begin (); 	 l != cnt.end(); ++l) {      pattern.push_back (make_pair <T, unsigned int> (l->first, l->second.size()));      project (l->first, l->second);      pattern.erase (pattern.end());    }  }public:  PrefixSpan (T _init,	      unsigned int _minsup = 1, 	      unsigned int _minpat = 1, 	      string _delimiter = "/",	      bool _verbose = false):    init (_init), minsup(_minsup), minpat (_minpat), delimiter (_delimiter), verbose (_verbose) {};  ~PrefixSpan () {};  istream &read (istream &is)   {    string line;    vector <T> tmp;    while (getline (is, line)) {      split (line, " ", tmp);      transaction.push_back (tmp);    }    return is;  }  void run (ostream &_os)  {    os = &_os;    vector <pair <unsigned int, int> > root;    for (unsigned int i = 0; i < transaction.size(); i++)       root.push_back (make_pair (i, -1));    project (init, root);   }  void clear ()  {    transaction.clear ();    pattern.clear ();  }};int main (int argc, char **argv){  extern char *optarg;  bool verbose = false;  unsigned int minsup = 1;  unsigned int minpat = 1;  string delimiter = "/";  bool useint = true;  int opt;  while ((opt = getopt(argc, argv, "vsM:m:d:")) != -1) {    switch(opt) {    case 'v':      verbose = true;      break;    case 'm':      minsup = atoi (optarg);      break;    case 'M':      minpat = atoi (optarg);      break;    case 's':      useint = false;      break;    case 'd':       delimiter = string (optarg);       break;    default:      cout << "Usage: " << argv[0] << " [-m minsup] [-M minpat] [-v] [-s] [-d delimiter] < data .." << endl;      return -1;    }  }  if (useint) {    PrefixSpan<unsigned int, string2int> prefixspan (0, minsup, minpat, delimiter, verbose);    prefixspan.read (cin);    prefixspan.run  (cout);  } else {    PrefixSpan<string, string2string> prefixspan ("", minsup, minpat, delimiter, verbose);     prefixspan.read (cin);    prefixspan.run  (cout);  }  return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲天堂成人网| 蜜臀a∨国产成人精品| 日韩影院在线观看| 成人黄色小视频| 欧美一区二区三区四区在线观看| 国产91精品一区二区麻豆亚洲| hitomi一区二区三区精品| 欧美日韩成人综合天天影院| 国产精品高潮呻吟久久| 看片的网站亚洲| 久久精品国产99久久6| 色婷婷香蕉在线一区二区| 久久久久青草大香线综合精品| 337p日本欧洲亚洲大胆色噜噜| 日韩精品中文字幕在线一区| 一区二区三区精品视频在线| 国产不卡视频一区| 欧美一级二级三级蜜桃| 亚洲电影激情视频网站| 色悠久久久久综合欧美99| 久久精品综合网| 最新热久久免费视频| 国产精品一区二区三区99| 欧美一卡二卡三卡四卡| 五月激情六月综合| 欧美日韩日日骚| 亚洲国产精品久久人人爱| 91亚洲精品乱码久久久久久蜜桃| 一本到三区不卡视频| 国产精品久久久久aaaa樱花| 国产精品一区不卡| 色久优优欧美色久优优| 亚洲欧洲日韩av| 91在线播放网址| 一区二区视频在线| 激情久久久久久久久久久久久久久久| 国产成人日日夜夜| 中文字幕精品一区二区精品绿巨人 | 久久蜜臀精品av| 亚洲欧美视频在线观看视频| 日本美女一区二区| 一区二区视频在线看| 色噜噜夜夜夜综合网| 一区二区三区在线免费视频| 91激情在线视频| 日韩综合小视频| 国产成人久久精品77777最新版本| 色先锋aa成人| 亚洲国产中文字幕在线视频综合| 激情综合一区二区三区| 91国偷自产一区二区三区成为亚洲经典| 欧美精品国产精品| 久久精品噜噜噜成人88aⅴ| 久久综合九色综合欧美就去吻| 亚洲国产视频直播| 日韩三级伦理片妻子的秘密按摩| 最新国产精品久久精品| 日本道色综合久久| 国产欧美日韩激情| 一本久道久久综合中文字幕| 国产欧美视频在线观看| 精品一区精品二区高清| 中文在线资源观看网站视频免费不卡 | 色综合久久久久综合体 | 国产精品资源在线看| 国产午夜精品福利| 精品婷婷伊人一区三区三| 美国毛片一区二区三区| 亚洲日本成人在线观看| 日韩午夜激情免费电影| av激情亚洲男人天堂| 视频一区二区三区在线| 国产精品乱人伦一区二区| 欧美三级电影在线看| 国产成人在线电影| 日韩精品电影在线观看| 国产精品理伦片| 日韩一级黄色片| 色国产精品一区在线观看| 极品少妇一区二区三区精品视频 | 懂色av中文一区二区三区| 亚洲精品日产精品乱码不卡| 一区二区三区中文字幕精品精品 | 国产成人免费视频一区| 国产亚洲综合在线| 国产一区二区三区四区五区美女 | 日韩精品一区二区三区在线播放| 日韩中文字幕一区二区三区| 欧美一区二区三级| 91丝袜国产在线播放| 日日嗨av一区二区三区四区| 亚洲猫色日本管| 欧美亚洲国产一区二区三区va| 亚洲一区二区三区三| 欧美激情一区二区三区不卡| 国产电影精品久久禁18| 男人的天堂久久精品| 亚洲精品国产品国语在线app| 欧美日韩一二三| eeuss鲁片一区二区三区| 国产毛片一区二区| 美女在线视频一区| 国产欧美一区二区精品婷婷| 精品99999| 欧美一区午夜精品| 欧美久久久久久久久中文字幕| 日本成人在线网站| 婷婷综合久久一区二区三区| 亚洲欧美日韩电影| 综合激情成人伊人| 国产精品久久久久四虎| 欧美日韩国产综合一区二区| 日本久久精品电影| 一本一道波多野结衣一区二区 | 国产精品国产三级国产普通话99 | 久久综合av免费| 日韩一级片在线观看| 欧美成人伊人久久综合网| 成人激情免费网站| 99久久婷婷国产| 99久久er热在这里只有精品15| 亚洲成人av电影| 亚洲va欧美va天堂v国产综合| 久久蜜臀中文字幕| 国产精品欧美久久久久一区二区| 欧美网站一区二区| 国产成人免费网站| 成人污污视频在线观看| a美女胸又www黄视频久久| 久久精品国内一区二区三区| 久久se精品一区精品二区| 国产精品一区久久久久| 丝袜美腿亚洲色图| 狠狠色丁香婷综合久久| 丁香婷婷深情五月亚洲| 色又黄又爽网站www久久| 成人性生交大片免费看中文| 成人18视频在线播放| 欧美色倩网站大全免费| 欧美刺激脚交jootjob| 国产精品免费丝袜| 五月婷婷久久丁香| 国产在线精品一区二区夜色| 日韩一区二区视频在线观看| 久久久天堂av| 亚洲激情图片qvod| 久久激五月天综合精品| 99精品国产视频| 日韩亚洲欧美高清| 国产欧美日韩精品在线| 丝袜美腿亚洲综合| 不卡的av网站| 91麻豆精品国产91久久久久| 在线免费观看日本欧美| 91精品国产欧美一区二区成人 | 国产大陆亚洲精品国产| 在线观看av一区二区| 亚洲精品一区二区在线观看| 亚洲免费av在线| 国产一区 二区| 欧美日韩精品高清| 国产精品久久看| 九色综合国产一区二区三区| 欧美性大战久久久| 日本一区二区三区久久久久久久久不| 日韩你懂的电影在线观看| 亚洲人成网站在线| 亚洲免费高清视频在线| 国产成人自拍在线| 欧美一二三在线| 一区二区免费看| 亚洲第一电影网| 成人激情动漫在线观看| 色哟哟国产精品| 精品视频一区二区不卡| 国产精品理论在线观看| 一区二区三区在线不卡| 国产精品自拍一区| 精品日韩在线一区| 日韩精品一二区| 欧美少妇一区二区| 亚洲日本中文字幕区| 成人三级在线视频| 久久亚洲二区三区| 麻豆高清免费国产一区| 欧美一区二区三区在线| 亚洲一区二区成人在线观看| 热久久一区二区| 欧美亚洲一区二区三区四区| 亚洲欧洲日韩在线| 日本人妖一区二区| 制服丝袜亚洲播放| 亚洲成av人**亚洲成av**| 欧美日韩在线播放| 亚洲成人激情自拍| 正在播放亚洲一区| 亚洲国产成人午夜在线一区| 狠狠色狠狠色综合| 久久婷婷成人综合色| 激情综合五月婷婷|