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

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

?? calcdb.cpp

?? clique code with sample data set. clique is a data clustering algorithm which follows hierarchical c
?? CPP
字號:
#include <iostream>
//#include <algo.h>
#include <algorithm>
#include "calcdb.h"
#include "eclat.h"

using namespace std;

int *Dbase_Ctrl_Blk::FreqIdx=NULL;
int *Dbase_Ctrl_Blk::FreqMap=NULL;
int Dbase_Ctrl_Blk::MaxTransSz=0;
int Dbase_Ctrl_Blk::TransSz=0;
int *Dbase_Ctrl_Blk::TransAry=NULL;
int Dbase_Ctrl_Blk::Tid=0;
int Dbase_Ctrl_Blk::Cid=0;
int Dbase_Ctrl_Blk::NumF1=0;
int Dbase_Ctrl_Blk::Cidsum=0;
int *Dbase_Ctrl_Blk::PvtTransAry=NULL;
int *Dbase_Ctrl_Blk::class_sz=NULL;
int *Dbase_Ctrl_Blk::F2sum=NULL;
vector<Eqnode *> Dbase_Ctrl_Blk::ParentClass;
bool Dbase_Ctrl_Blk::binary_input=false;

Dbase_Ctrl_Blk::Dbase_Ctrl_Blk(const char *infile, const int buf_sz)
{
   if (binary_input){
      fd.open(infile, ios::in|ios::binary);
      if (!fd){
         cerr << "cannot open infile" << infile << endl;
         exit(1);
      }
   }
   else{
      fd.open(infile, ios::in);
      if (!fd){
         cerr << "cannot open infile" << infile << endl;
         exit(1);
      }
   }   

   buf_size = buf_sz;
   buf = new int [buf_sz];
   cur_buf_pos = 0;
   cur_blk_size = 0;
   readall = 0;
   fd.seekg(0,ios::end);
   endpos = fd.tellg();
   fd.seekg(0,ios::beg);
}
   
Dbase_Ctrl_Blk::~Dbase_Ctrl_Blk()
{
   delete [] buf;
   fd.close();
}

void Dbase_Ctrl_Blk::get_first_blk()
{
   readall=0;

   fd.clear();
   fd.seekg(0,ios::beg);
   
   if (binary_input){
      fd.read((char *)buf, (buf_size*ITSZ));
      cur_blk_size = fd.gcount()/ITSZ; 
      if (cur_blk_size < 0){
         cerr << "problem in get_first_blk" << cur_blk_size << endl;
      }
   }
   
   cur_buf_pos = 0;
}

int Dbase_Ctrl_Blk::get_next_trans ()
{
   static char first=1;  
   static int lastCid = 0;

   // cout << "First = " << (int)(first) << endl;

   if (first){
      first = 0;
      get_first_blk();
   }

   if (binary_input){
     // cout << "Binary input" << endl;

      if (cur_buf_pos+TRANSOFF >= cur_blk_size ||
          cur_buf_pos+buf[cur_buf_pos+TRANSOFF-1]+TRANSOFF > cur_blk_size){



         fd.seekg(0,ios::cur);
         if ((int)fd.tellg() == endpos) readall = 1;      
         if (!readall){
            // Need to get more items from file
	   // cout << "Need to get more" << endl;
	   get_next_trans_ext();
         }      
      }
      
      if (eof()){
	// cout << "eof" << endl;
         first = 1;
         return 0;
      }                     
      
      if (!readall){
         Cid = buf[cur_buf_pos];
	 if(Cid < lastCid){
	   first = 1;
	   lastCid = 0;
	   return 0;
	 }
	 else{
	   lastCid = Cid;
	 }
         Tid = buf[cur_buf_pos+TRANSOFF-2];
         TransSz = buf[cur_buf_pos+TRANSOFF-1];
         TransAry = buf + cur_buf_pos + TRANSOFF;
         cur_buf_pos += TransSz + TRANSOFF;

	 /* cout << "Transaction: CID = " << Cid << " TID = " << Tid << " size = " << TransSz << endl;
	 for(int i = 0; i < TransSz; i++){
	   cout << "Item " << buf[cur_buf_pos + TRANSOFF + i] << endl;
	   }*/

      }
      return 1;
   }
   else{
     //cout << "Non binary input" << endl;
      //fd.seekg(0,ios::cur);
      //if (fd.tellg() == endpos) readall = 1;

      if ((int)fd.tellg() == endpos-1){
         readall = 1;
         first = 1;
         return 0;
      }
      else{
         int i;
         fd >> Cid;
         fd >> Tid;
         fd >> TransSz;
         for (i=0; i < TransSz; ++i){
            fd >> buf[i];
         }
         TransAry = buf;
         cur_buf_pos = 0;

         //cout << "ENDPOS " << fd.tellg() << " " << endpos << endl;

         return 1;
      }
   }
}

void Dbase_Ctrl_Blk::get_next_trans_ext()
{
   // Need to get more items from file
   int res = cur_blk_size - cur_buf_pos;
   if (res > 0)
   {
      // First copy partial transaction to beginning of buffer
      for (int i=0; i < res; ++i)
         buf[i] = buf[cur_buf_pos+i]; 
      cur_blk_size = res;
   }
   else
   {
      // No partial transaction in buffer
      cur_blk_size = 0;
   }

   fd.read((char *)(buf + cur_blk_size),
           ((buf_size - cur_blk_size)*ITSZ));
   
   res = fd.gcount();
   if (res < 0){
      cerr << "in get_next_trans_ext" << res << endl;
   }
   
   cur_blk_size += res/ITSZ;
   cur_buf_pos = 0;
}


void Dbase_Ctrl_Blk::get_valid_trans()
{
   int i,j;
   const int invalid=-1; //-1 does not appear in original trans
   
   if (PvtTransAry == NULL)
      PvtTransAry = new int [MaxTransSz];
   
   //copy valid items to PvtTransAry
   for (i=0,j=0; i < TransSz; ++i){
      if (FreqMap[TransAry[i]] != invalid){
         PvtTransAry[j] = FreqMap[TransAry[i]];
         ++j;
      }
   }
   TransAry = PvtTransAry;
   TransSz = j;

   //cout << "NEW " << endl;
   //for (i=0; i < TransSz; ++i)
   //   cout << TransAry[i] << " ";
   //cout << endl;
}

void Dbase_Ctrl_Blk::print_trans(){
  cout << Cid << " " << Tid << " " << TransSz;
  for (int i=0; i < TransSz; ++i)
    cout << " " << TransAry[i];
  cout << endl;
}


void Dbase_Ctrl_Blk::alloc_ParentClass(vector<int> &itcnt)
{
   //allocate space for Idlists
   ParentClass.resize(NumF1);
   for (int i=0; i < NumF1; ++i){
      ParentClass[i] = new Eqnode(i, itcnt[FreqIdx[i]]);   
      if (diff_type == diffin) ParentClass[i]->hval = Cidsum;
   }
}

bool Dbase_Ctrl_Blk::incr_cmp(Eqnode *n1, Eqnode *n2)
{
   if (class_sz[n1->val] < class_sz[n2->val]) return true;
   else if (class_sz[n1->val] == class_sz[n2->val]){
      if (F2sum[n1->val] < F2sum[n2->val]) return true;
      else if (F2sum[n1->val] == F2sum[n2->val]){
         if (n1->sup < n2->sup) return true;
         else return false;
     }
      else return false;
   }
   else return false;
   //if (F2sum[n1->val] < F2sum[n2->val]) return true;
   //else return false;
}

bool Dbase_Ctrl_Blk::decr_cmp(Eqnode *n1, Eqnode *n2)
{
   return !incr_cmp(n1,n2);
}

void Dbase_Ctrl_Blk::sort_ParentClass()
{
   if (sort_type == incr) 
      sort(ParentClass.begin(), ParentClass.end(), incr_cmp);
   else if (sort_type == incr_noclass) 
      sort(ParentClass.begin(), ParentClass.end(), Eqnode::incr_cmp);
   else if (sort_type == decr) 
      sort(ParentClass.begin(), ParentClass.end(), decr_cmp);
}


//assumes that get_valid_trans has been called before
void Dbase_Ctrl_Blk::make_vertical(){
   int i, j;
   
   //convert current transaction into vertical format
   if (diff_type == diffin){
      //create a diffset
      for (i=0, j=0; i < TransSz; ++j){
         if (j == TransAry[i]){
            ++i; 
         }
         else{
            ParentClass[j]->tidset.push_back(Cid);
            ParentClass[j]->hval -= Cid; //used for closed sets
         }
      }
      for (; j < NumF1; ++j){
         ParentClass[j]->tidset.push_back(Cid);
         ParentClass[j]->hval -= Cid; //used for closed sets
      }
      
   }
   else{
      //create a tidset
      for (i=0; i < TransSz; ++i){
         //cout << "push " << TransAry[i] << " " << Cid << endl;
         ParentClass[TransAry[i]]->tidset.push_back(Cid);
         ParentClass[TransAry[i]]->hval += Cid; //used for closed sets
      }
   }
}


void Dbase_Ctrl_Blk::print_vertical(){
  int i;
  for (i=0; i < NumF1; ++i){
    cout << *ParentClass[i];
  }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久亚洲综合| 亚洲国产你懂的| 亚洲综合av网| 国产中文字幕精品| 欧美日韩精品是欧美日韩精品| 337p日本欧洲亚洲大胆色噜噜| 一区二区激情视频| 国产精品99精品久久免费| 欧美日韩夫妻久久| 亚洲综合在线第一页| www.欧美精品一二区| 欧美tk丨vk视频| 调教+趴+乳夹+国产+精品| 不卡一区二区中文字幕| 亚洲精品一区二区三区福利| 亚洲一区二区精品视频| 91视频在线看| 一区在线观看视频| 国产91在线看| 久久精品欧美日韩| 国产在线精品一区在线观看麻豆| 91.麻豆视频| 日本不卡123| 88在线观看91蜜桃国自产| 亚洲成国产人片在线观看| 欧美性xxxxxxxx| 亚洲一区二区偷拍精品| 91热门视频在线观看| 中日韩av电影| 不卡的av在线播放| 日韩伦理av电影| 色视频一区二区| 亚洲精品免费在线播放| 欧美日韩亚洲综合在线 | 精品在线一区二区| 91精品国产综合久久久蜜臀图片 | 欧美日韩不卡一区| 亚洲高清一区二区三区| 欧美日韩二区三区| 日产国产欧美视频一区精品| 91精品国产免费久久综合| 青青草原综合久久大伊人精品优势| 欧美日韩国产高清一区二区| 日韩精品91亚洲二区在线观看| 欧美日韩国产综合视频在线观看| 日日夜夜精品视频天天综合网| 日韩欧美一区二区视频| 精品一区二区三区免费毛片爱| 久久亚洲捆绑美女| 99久久99久久精品免费观看| 亚洲综合色自拍一区| 日韩视频永久免费| 成人av电影在线播放| 一区av在线播放| 日韩女优av电影| 高清国产一区二区三区| 一区二区三区在线观看动漫| 欧美精品在线视频| 丁香婷婷深情五月亚洲| 亚洲午夜羞羞片| 久久综合久久综合九色| 91在线视频免费91| 蜜乳av一区二区| 国产精品人妖ts系列视频| 欧美日韩在线三区| 国产麻豆成人传媒免费观看| 亚洲乱码国产乱码精品精小说| 欧美日韩在线观看一区二区 | 欧美一级二级三级乱码| 国产精品短视频| 成人性生交大片免费看中文网站| 日本丰满少妇一区二区三区| 精品乱人伦小说| 日韩av在线播放中文字幕| 91伊人久久大香线蕉| 国产精品久久久久一区二区三区共| 亚洲精品久久嫩草网站秘色| 91猫先生在线| 亚洲少妇屁股交4| 成人av综合在线| 久久先锋资源网| 国产在线一区二区| 日韩精品一区二区在线观看| 有坂深雪av一区二区精品| 国产精品1区2区| 国产欧美日韩激情| 激情成人综合网| 久久先锋影音av| 麻豆专区一区二区三区四区五区| 欧美精品久久久久久久多人混战| 亚洲黄色片在线观看| 色综合天天性综合| 日本成人在线看| 国产亚洲欧美一区在线观看| 麻豆极品一区二区三区| 精品乱人伦小说| 成人精品视频网站| 一区二区三区视频在线看| 日本高清成人免费播放| av在线不卡免费看| 国产综合色产在线精品| 亚洲色图另类专区| 成人av在线一区二区三区| 日韩和欧美一区二区| 91精品国产综合久久婷婷香蕉| 成人小视频在线| 国产精品成人午夜| 欧美特级限制片免费在线观看| 日韩高清国产一区在线| 亚洲成a天堂v人片| 99久久精品99国产精品| 欧美日韩成人高清| 精品国产a毛片| 欧美一卡二卡三卡| 色综合天天综合网国产成人综合天 | 国产精品久久久99| 国产精品青草综合久久久久99| 久久嫩草精品久久久精品一| 日韩精品在线网站| 色哟哟欧美精品| 成人在线综合网| 美国十次综合导航| 首页欧美精品中文字幕| 亚洲成人资源网| 国产精品私人自拍| 欧美精品一区二区久久久| 国产精品视频免费| 久久久777精品电影网影网 | 日韩国产成人精品| 视频精品一区二区| 强制捆绑调教一区二区| 久久99久久99| 成人性色生活片| 色噜噜狠狠色综合中国| 欧美日韩五月天| 精品日韩一区二区三区免费视频| 亚洲精品一区二区三区四区高清| 日本一区二区三区四区| 综合色天天鬼久久鬼色| 婷婷综合五月天| 久久99精品久久久久| 国产.欧美.日韩| 欧美午夜不卡在线观看免费| 欧美mv日韩mv| 国产精品久久久久久久久晋中| 亚洲一区二区三区影院| 极品少妇一区二区| 91麻豆精品秘密| 欧美va亚洲va在线观看蝴蝶网| 中文字幕亚洲一区二区av在线| 天天综合色天天| 成人午夜在线视频| 91精品综合久久久久久| 国产日韩成人精品| 天堂在线一区二区| 97久久超碰国产精品| 精品久久久三级丝袜| 亚洲天天做日日做天天谢日日欢| 日本不卡中文字幕| 91精品办公室少妇高潮对白| 日韩欧美国产综合在线一区二区三区| 国产精品久久久久久久久动漫 | 久久er精品视频| 色综合一区二区| 精品免费一区二区三区| 亚洲自拍欧美精品| 国产成人亚洲精品青草天美| 91精品蜜臀在线一区尤物| 中文字幕在线观看不卡| 久久99深爱久久99精品| 欧美日韩小视频| 亚洲精品国久久99热| 成人免费毛片片v| 欧美成va人片在线观看| 午夜精品久久久久久久久久久 | 欧美一级片在线观看| 一区二区三区四区不卡视频| 丰满少妇在线播放bd日韩电影| 日韩视频免费观看高清完整版在线观看| 国产精品免费观看视频| 国产综合成人久久大片91| 91精品国产欧美一区二区18| 亚洲一二三四区不卡| 色综合久久久网| 亚洲日韩欧美一区二区在线| 成人手机在线视频| 日韩午夜电影av| 热久久久久久久| 欧美日韩一区成人| 亚洲一二三四区不卡| 欧美午夜一区二区三区免费大片| 国产精品天美传媒| 99在线精品一区二区三区| 日本一区二区视频在线| 成人毛片在线观看| 欧美韩国日本综合| 91在线观看视频| 亚洲精品欧美激情| 欧美伊人久久久久久久久影院 | 欧美激情综合五月色丁香|