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

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

?? tract.c

?? apriori算法是數據挖掘的經典算法之1,其基于關聯規則的思想.這是我的第2個收藏算法
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*----------------------------------------------------------------------  File    : tract.c  Contents: item and transaction management  Author  : Christian Borgelt  History : 14.02.1996 file created as apriori.c            24.06.1996 function _get_item optimized            01.07.1996 adapted to modified symtab module            04.01.1998 scan functions moved to module 'tfscan'            09.06.1998 vector enlargement modified            20.06.1998 adapted to changed st_create function            07.08.1998 bug in function _get_tract (is_read) fixed            08.08.1998 item appearances added            17.08.1998 item sorting and recoding added            02.09.1998 several assertions added            05.02.1999 long int changed to int            22.10.1999 bug in item appearances reading fixed            11.11.1999 adapted to name/identifier maps            01.12.1999 check of item appearance added to sort function            15.03.2000 removal of infrequent items added            14.07.2001 adapted to modified module tfscan            27.12.2001 item functions made a separate module            18.11.2001 transaction functions made a separate module            28.12.2001 first version of this module completed            12.01.2002 empty field at end of record reported as error            06.02.2002 item sorting reversed (ascending order)----------------------------------------------------------------------*/#include <stdio.h>#include <stdlib.h>#include <string.h>#include <assert.h>#include "tract.h"#include "vecops.h"#ifdef STORAGE#include "storage.h"#endif/*----------------------------------------------------------------------  Preprocessor Definitions----------------------------------------------------------------------*/#define BLKSIZE  256            /* block size for enlarging vectors *//*----------------------------------------------------------------------  Constants----------------------------------------------------------------------*//* --- item appearance indicators --- */static const char *i_body[] = { /* item to appear in bodies only */  "i",  "in",  "a", "ante", "antecedent", "b", "body", NULL };static const char *i_head[] = { /* item to appear in heads only */  "o",  "out", "c", "cons", "consequent", "h", "head", NULL };static const char *i_both[] = { /* item to appear in both */  "io", "inout", "ac", "bh", "both",                   NULL };static const char *i_ignore[] ={/* item to ignore */  "n", "neither", "none", "ign", "ignore", "-",        NULL };/*----------------------------------------------------------------------  Auxiliary Functions----------------------------------------------------------------------*/static int _appcode (const char *s){                               /* --- get appearance indicator code */  const char **p;               /* to traverse indicator list */  assert(s);                    /* check the function argument */  for (p = i_body;   *p; p++)   /* check 'body' indicators */    if (strcmp(s, *p) == 0) return APP_BODY;  for (p = i_head;   *p; p++)   /* check 'head' indicators */    if (strcmp(s, *p) == 0) return APP_HEAD;  for (p = i_both;   *p; p++)   /* check 'both' indicators */    if (strcmp(s, *p) == 0) return APP_BOTH;  for (p = i_ignore; *p; p++)   /* check 'ignore' indicators */    if (strcmp(s, *p) == 0) return APP_NONE;  return -1;                    /* if none found, return error code */}  /* _appcode() *//*--------------------------------------------------------------------*/static int _get_item (ITEMSET *iset, FILE *file){                               /* --- read an item */  int  d;                       /* delimiter type */  char *buf;                    /* read buffer */  ITEM *item;                   /* pointer to item */  int  *vec;                    /* new item vector */  int  size;                    /* new item vector size */  assert(iset && file);         /* check the function arguments */  d   = tfs_getfld(iset->tfscan, file, NULL, 0);  buf = tfs_buf(iset->tfscan);  /* read the next field (item name) */  if ((d < 0) || (buf[0] == '\0')) return d;  item = nim_byname(iset->nimap, buf);  if (item)                     /* look up the name in name/id map */    item->frq++;                /* if it could be found, count it */  else {                        /* if it could not be found: */    if (iset->app == APP_NONE)  /* if new items are to be ignored, */      return d;                 /* do not register the item */    item = nim_add(iset->nimap, buf, sizeof(ITEM));    if (!item) return E_NOMEM;  /* add the new item to the map, */    item->frq = 1;              /* initialize the frequency counter, */    item->app = iset->app;      /* and set the appearance indicator */  }  size = iset->vsz;             /* get the item vector size */  if (iset->cnt >= size) {      /* if the item vector is full */    size += (size > BLKSIZE) ? (size >> 1) : BLKSIZE;    vec   = (int*)realloc(iset->items, size *sizeof(int));    if (!vec) return E_NOMEM;   /* enlarge the item vector */    iset->items = vec; iset->vsz = size;  }                             /* set the new vector and its size */  iset->items[iset->cnt++] = item->id;  return d;                     /* add the item to the transaction */}  /* _get_item() */            /* and return the delimiter type *//*--------------------------------------------------------------------*/static int _asccmp (const void *p1, const void *p2, void *data){                               /* --- compare item frequencies */  if (((const ITEM*)p1)->app == APP_NONE)    return (((const ITEM*)p2)->app == APP_NONE) ? 0 : 1;  if (((const ITEM*)p2)->app == APP_NONE) return -1;  if (((const ITEM*)p1)->frq < (int)data)    return (((const ITEM*)p2)->frq < (int)data) ? 0 : 1;  if (((const ITEM*)p2)->frq < (int)data) return -1;  if (((const ITEM*)p1)->frq > ((const ITEM*)p2)->frq) return  1;  if (((const ITEM*)p1)->frq < ((const ITEM*)p2)->frq) return -1;  return 0;                     /* return sign of frequency diff. */}  /* _asccmp() *//*--------------------------------------------------------------------*/static int _descmp (const void *p1, const void *p2, void *data){                               /* --- compare item frequencies */  if (((const ITEM*)p1)->app == APP_NONE)    return (((const ITEM*)p2)->app == APP_NONE) ? 0 : 1;  if (((const ITEM*)p2)->app == APP_NONE) return -1;  if (((const ITEM*)p1)->frq > ((const ITEM*)p2)->frq) return -1;  if (((const ITEM*)p1)->frq < ((const ITEM*)p2)->frq) return  1;  return 0;                     /* return sign of frequency diff. */}  /* _descmp() *//*----------------------------------------------------------------------  Item Set Functions----------------------------------------------------------------------*/ITEMSET* is_create (void){                               /* --- create an item set */  ITEMSET *iset;                /* created item set */  iset = malloc(sizeof(ITEMSET));  if (!iset) return NULL;       /* create an item set */  iset->tfscan = tfs_create();  /* and its components */  iset->nimap  = nim_create(0, 0, (HASHFN*)0, (SYMFN*)0);  iset->items  = (int*)malloc(BLKSIZE *sizeof(int));  if (!iset->tfscan || !iset->nimap || !iset->items) {    is_delete(iset); return NULL; }  iset->app    = APP_BOTH;      /* initialize the other fields */  iset->vsz    = BLKSIZE;  iset->cnt    = 0;  iset->chars[0] = ' ';  iset->chars[1] = ' ';  iset->chars[2] = '\n'; iset->chars[3] = '\0';  return iset;                  /* return the created item set */}  /* is_create() *//*--------------------------------------------------------------------*/void is_delete (ITEMSET *iset){                               /* --- delete an item set */  assert(iset);                 /* check the function argument */  if (iset->items)  free(iset->items);  if (iset->nimap)  nim_delete(iset->nimap);  if (iset->tfscan) tfs_delete(iset->tfscan);  free(iset);                   /* delete the components */}  /* is_delete() */            /* and the item set body *//*--------------------------------------------------------------------*/void is_chars (ITEMSET *iset, const char *blanks,  const char *fldseps,                              const char *recseps, const char *cominds){                               /* --- set special characters */  assert(iset);                 /* check the function argument */  if (blanks)                   /* set blank characters */    iset->chars[0] = tfs_chars(iset->tfscan, TFS_BLANK,  blanks);  if (fldseps)                  /* set field separators */    iset->chars[1] = tfs_chars(iset->tfscan, TFS_FLDSEP, fldseps);  if (recseps)                  /* set record separators */    iset->chars[2] = tfs_chars(iset->tfscan, TFS_RECSEP, recseps);  if (cominds)                  /* set comment indicators */    tfs_chars(iset->tfscan, TFS_COMMENT, cominds);}  /* is_chars() *//*--------------------------------------------------------------------*/int is_item (ITEMSET *iset, const char *name){                               /* --- get an item identifier */  ITEM *item = nim_byname(iset->nimap, name);  return (item) ? item->id :-1; /* look up the given name */}  /* is_item() */              /* in the name/identifier map *//*--------------------------------------------------------------------*/int is_readapp (ITEMSET *iset, FILE *file){                               /* --- read appearance indicators */  int  d;                       /* delimiter type */  char *buf;                    /* read buffer */  ITEM *item;                   /* to access the item data */  assert(iset && file);         /* check the function arguments */  if (tfs_skip(iset->tfscan, file) < 0)    return E_FREAD;             /* skip leading comments */  buf = tfs_buf(iset->tfscan);  /* read the first record (one field) */  d   = tfs_getfld(iset->tfscan, file, NULL, 0);  if (d <  0)           return E_FREAD;  if (d >= TFS_FLD)     return E_FLDCNT;  iset->app = _appcode(buf);    /* get default appearance code */  if (iset->app < 0)    return E_UNKAPP;  while (d > TFS_EOF) {         /* read item/indicator pairs */    if (tfs_skip(iset->tfscan, file) < 0)      return E_FREAD;           /* skip more comments */    d = tfs_getfld(iset->tfscan, file, NULL, 0);    if (d <= TFS_EOF)           /* read the next item */      return (d < 0) ? E_FREAD : 0;    if (buf[0] == '\0')         /* check for end of file */      return E_ITEMEXP;         /* and for a missing item */    item = nim_add(iset->nimap, buf, sizeof(ITEM));    if (item == EXISTS) return E_DUPITEM;  /* add the new item */    if (item == NULL)   return E_NOMEM;    /* to the name/id map */    item->frq = 0;              /* clear the frequency counter */    if (d < TFS_FLD)    return E_APPEXP;    d = tfs_getfld(iset->tfscan, file, NULL, 0);    if (d <  0)         return E_FREAD;    if (d >= TFS_FLD)   return E_FLDCNT;    item->app = _appcode(buf);  /* get the appearance indicator */    if (item->app <  0)  return E_UNKAPP;  }  return 0;                     /* return 'ok' */}  /* is_readapp() *//*--------------------------------------------------------------------*/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品日韩在线观看| 在线亚洲+欧美+日本专区| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 国产激情偷乱视频一区二区三区| 亚洲综合一区二区三区| 一区二区三区不卡视频在线观看 | 亚洲欧洲中文日韩久久av乱码| 中文字幕+乱码+中文字幕一区| 久久精品视频免费| 久久久亚洲欧洲日产国码αv| 国产亚洲欧美在线| 国产精品午夜电影| 亚洲欧美激情在线| 亚洲国产一区二区在线播放| 亚洲第一狼人社区| 久久福利视频一区二区| 国产精品综合一区二区三区| 国产91清纯白嫩初高中在线观看| 成人综合婷婷国产精品久久蜜臀| 一本高清dvd不卡在线观看| 欧美亚洲图片小说| 欧美一区二区在线不卡| 久久久亚洲高清| 9191久久久久久久久久久| 国产一区在线观看视频| 国产成人aaaa| 91精彩视频在线观看| 欧美视频一区二| 日韩欧美成人激情| 国产精品久久久久久久岛一牛影视 | 99精品视频在线免费观看| 色哟哟国产精品| 91精品国产高清一区二区三区| 久久中文娱乐网| 成人激情av网| 国产精品1区二区.| 欧美高清激情brazzers| 国产欧美一区二区三区沐欲| 国产日产亚洲精品系列| 亚洲欧美韩国综合色| 亚洲一区二区影院| 日本欧美在线看| 高清在线不卡av| 久久综合狠狠综合久久激情 | 午夜精品久久久久久久99樱桃| 亚洲制服丝袜av| 九色综合狠狠综合久久| 波多野结衣亚洲| 69av一区二区三区| 国产精品女主播在线观看| 亚洲最大成人综合| 国产九色精品成人porny | 精品国产免费一区二区三区香蕉| 欧美国产欧美综合| 天天av天天翘天天综合网| 国产精品一区在线观看你懂的| 欧美性色黄大片| 久久久精品2019中文字幕之3| 亚洲国产视频网站| 成人动漫视频在线| 日韩欧美国产小视频| 亚洲欧美一区二区三区久本道91| 精品一区二区三区免费视频| 精品婷婷伊人一区三区三| 亚洲国产精品av| 久久精品国产77777蜜臀| 欧美做爰猛烈大尺度电影无法无天| 久久久777精品电影网影网| 天堂一区二区在线| 在线一区二区三区四区| 国产欧美在线观看一区| 久久国产精品99久久人人澡| 欧美性视频一区二区三区| 国产精品区一区二区三| 久久av中文字幕片| 欧美一区二区在线看| 亚洲一区二区三区中文字幕| gogogo免费视频观看亚洲一| 久久综合色播五月| 奇米精品一区二区三区四区 | 亚洲国产精品高清| 激情欧美一区二区| 精品乱人伦小说| 亚洲一区二区三区四区五区黄| 国产三级一区二区三区| 成人高清av在线| 国产精品久久久久久久久搜平片 | 91麻豆精品国产无毒不卡在线观看 | 欧美成人a∨高清免费观看| 亚洲免费资源在线播放| 福利一区福利二区| 久久久噜噜噜久噜久久综合| 免费成人性网站| 91精品国产综合久久精品图片| 亚洲午夜精品久久久久久久久| 色综合久久久久久久久久久| 中文字幕av一区 二区| 国产乱人伦精品一区二区在线观看 | 成av人片一区二区| 国产欧美一区二区三区鸳鸯浴| 激情亚洲综合在线| 久久久美女毛片| 国产馆精品极品| 亚洲国产岛国毛片在线| 国产成人免费视频一区| 国产视频在线观看一区二区三区| 国产精品一区二区视频| 久久噜噜亚洲综合| 国产电影一区在线| 国产精品久久久久天堂| 91片黄在线观看| 国产麻豆成人传媒免费观看| 91麻豆国产福利精品| 最近中文字幕一区二区三区| 91亚洲精品久久久蜜桃网站| 亚洲三级在线观看| 欧美亚洲综合网| 天堂成人免费av电影一区| 欧美精品123区| 欧美aaaaaa午夜精品| 精品日韩成人av| 国产河南妇女毛片精品久久久 | 亚洲乱码中文字幕| 日本久久电影网| 五月婷婷另类国产| 日韩和欧美一区二区三区| 欧美视频一区二| 67194成人在线观看| 精品99一区二区| 91精品欧美综合在线观看最新| 99久久精品免费观看| 国内精品伊人久久久久av一坑| 一区二区三区四区蜜桃| 1区2区3区精品视频| 欧美激情中文字幕一区二区| 精品久久久网站| 精品久久国产老人久久综合| 欧美成人精品1314www| 粉嫩一区二区三区在线看| 中文字幕精品在线不卡| 在线影院国内精品| 久久99精品久久久久婷婷| 国产精品盗摄一区二区三区| 欧美乱熟臀69xxxxxx| 国产精品91一区二区| 亚洲男女毛片无遮挡| 欧美一区二区在线免费观看| 国产成人午夜视频| 亚洲综合色视频| 久久奇米777| 在线观看亚洲精品| 国产精品白丝jk黑袜喷水| 亚洲综合男人的天堂| 精品国产自在久精品国产| 色噜噜狠狠色综合中国| 经典一区二区三区| 亚洲综合成人在线视频| 国产午夜精品美女毛片视频| 欧美色视频在线观看| 国产成人在线视频免费播放| 亚洲高清免费观看高清完整版在线观看| 久久综合色之久久综合| 欧美日韩在线三级| 大桥未久av一区二区三区中文| 视频一区国产视频| 亚洲免费视频成人| 久久久久免费观看| 91麻豆精品国产自产在线 | 久久国产精品第一页| 亚洲精品国产精华液| 久久久久久97三级| 欧美精品亚洲一区二区在线播放| eeuss鲁片一区二区三区在线看| 蜜桃av一区二区在线观看| 一区二区三区 在线观看视频| 国产欧美精品日韩区二区麻豆天美| 91精品国产综合久久久久久久| 色94色欧美sute亚洲线路二| 国产成人免费视频| 狠狠色丁香九九婷婷综合五月| 亚洲成人一二三| 亚洲综合一区二区| 亚洲色图在线播放| 一区在线播放视频| 国产网红主播福利一区二区| 精品国精品自拍自在线| 欧美一区二区三区啪啪| 欧美日韩精品福利| 在线视频国内一区二区| 91美女在线视频| 成人性视频网站| 国产河南妇女毛片精品久久久| 精品伊人久久久久7777人| 图片区日韩欧美亚洲| 性久久久久久久| 亚洲国产一区二区三区青草影视| 亚洲三级免费电影| 尤物av一区二区| 一区二区三区欧美久久| 一区二区三区四区精品在线视频|