亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

Species Tree 利用HashTable實現實例代碼

2020-05-23 13:53:47
字體:
來源:轉載
供稿:網友

Species Tree 利用HashTable實現

題目再現

題目內容:

給定一個物種演化圖,關系的表示方式如下:x y : 表示x為y的先祖。一個物種只會有一個先祖,一個先祖可以有很多個演化出來的物種,請你找出每個問題詢問物種的祖父物種(先祖的先祖),每個物種會使用一個不重復的編號來表示,如果該物種沒有祖父物種的話或是不存在,那么請將他的祖父物種當是0。(憑空而生)保證所有物種間一定有所關連,且不會有重復演化的現象發生,即演化圖只會是一棵樹。輸入格式:只有一組測資。第一行會有兩個數字N、Q,代表總共有N個物種及Q個問題。接下來N-1行,每一行有兩個數字x、y,意義如題目所述。接下來的Q行,每一行有一個數字Z,代表要詢問的物種編號。測資范圍:1 < N < 100000 < Q < 10000 < x, y, z < 1000000輸出格式:對于每一個詢問的物種編號,將他們的祖父物種編號加總后再輸出。輸入樣例:6 31000 20001000 30002000 40003000 50005000 6000500060001234輸出樣例:4000時間限制:100ms內存限制:16000kb

算法實現

1. 簡單數組下標查找法

  通過題目的要求,這里可以使用最簡單的方法,因為輸入的x , y中,y的值是確定不變的,所以這里可以定義一個y的取值范圍那么大的數組,下標就是y的值,內容就是x的值,這樣查找起來十分方便,時間復雜度是O(1),但是空間上就會浪費比較多了。

#include <stdio.h>#include <string.h>int main(){  int arrBucket[1000000];  int N, Q;  int x, y, z;  long long sum = 0;  memset(arrBucket, 0, sizeof(arrBucket));  scanf("%d %d", &N, &Q);  while(N -- > 1){    scanf("%d %d", &x, &y);    arrBucket[y] = x;  }  while(Q --){    scanf("%d", &z);    if(arrBucket[z] != 0){      if(arrBucket[arrBucket[z]] != 0){        sum += arrBucket[arrBucket[z]];      }    }  }  printf("%lld", sum);  return 0;}

2. Hash表實現

  因為方法1中,浪費空間嚴重,所以這里使用Hash表實現。

#include <stdio.h>#include <stdlib.h>#define NULLKEY -1typedef struct {  int *elem; //元素   int *elemP; //父元素   int count;}HashTable;int Hash(HashTable H, int k){  return k % H.count;}void InitHashTable(HashTable *H){  int i;  H->elem = (int *)malloc(sizeof(int) * H->count);  H->elemP = (int *)malloc(sizeof(int) * H->count);  for(i = 0; i < H->count; i ++){    H->elem[i] = NULLKEY;    H->elemP[i] = NULLKEY;   }}void InsertHash(HashTable *H, int key, int value){  int addr;  addr = Hash(*H, key);  while(H->elem[addr] != NULLKEY){    addr = (addr + 1) % H->count;  }  H->elem[addr] = key;  H->elemP[addr] = value;}int FindHash(HashTable *H, int key, int *addr){  *addr = Hash(*H, key);  while(H->elem[*addr] != key){    *addr = (*addr + 1) % H->count;    if(H->elem[*addr] == NULLKEY || *addr == Hash(*H, key)){      return 0;    }  }  return 1;}int main(){  int N, Q;  int x, y, z, addr;  long long sum = 0;  HashTable H;  scanf("%d %d", &N, &Q);  H.count = N - 1;  InitHashTable(&H);  while(N -- > 1){    scanf("%d %d", &x, &y);    InsertHash(&H, y, x);  }  while(Q --){    scanf("%d", &z);    if(FindHash(&H, z, &addr)){      if(FindHash(&H, H.elemP[addr], &addr)){        sum += H.elemP[addr];      }    }  }  printf("%lld", sum);  return 0;}

3. 用C++的map來實現

  看著用C實現起來,相對來說實現的各個功能都要自己寫,這里看一下用C++的STL里面的map來實現上面的題目,非常簡單(不得不說STL真的很好用,但是不如HashTable速度快,空間上也不如HashTable占用的小)

#include <iostream>#include <map>using namespace std;int main() {  int n, q;  cin >> n >> q;  map<int,int> mp;   map<int,int>::iterator it;  int x, y, z;  for (int i=1; i<n; ++i) {      cin >> x >> y;    mp.insert(pair<int,int>(y,x));    }  int sum = 0;  for (int i=0; i<q; ++i) {    cin >> z;    it = mp.find(z);      if (it != mp.end()) {      it = mp.find(it->second);        if (it != mp.end())        sum += it->second;      }  }  cout << sum;  return 0;}

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性猛交xxxx偷拍洗澡| 国产视频丨精品|在线观看| 91啪国产在线| 中文字幕精品影院| 欧美猛少妇色xxxxx| 欧美高清一级大片| 国产精品久久久久免费a∨| 日韩在线激情视频| 日韩美女av在线| 日韩av免费看网站| 亚洲在线免费观看| 国产亚洲欧美aaaa| 精品久久久久国产| 性日韩欧美在线视频| 精品久久国产精品| 欧美在线性视频| 少妇高潮 亚洲精品| 国产主播欧美精品| 97香蕉超级碰碰久久免费的优势| 亚洲精品自拍视频| 91免费在线视频| 欧美在线视频导航| 91国内免费在线视频| 日韩欧美中文第一页| 亚洲美女黄色片| 一区二区三区久久精品| 亚洲影院在线看| 精品国产一区二区三区久久| 粉嫩老牛aⅴ一区二区三区| 久久成人精品一区二区三区| 欧美日韩国产丝袜另类| 日韩在线视频国产| 国产精品久久久久久久7电影| 欧美性猛交xxxx黑人| 精品视频久久久久久久| 91精品久久久久久久久久久久久| 中文字幕av日韩| 亚洲欧美成人一区二区在线电影| 亚洲成人av在线| 成人免费xxxxx在线观看| 国产做受高潮69| 国产精品视频永久免费播放| 91po在线观看91精品国产性色| 自拍偷拍亚洲在线| 成人久久18免费网站图片| 日韩精品在线播放| 亚洲精品乱码久久久久久金桔影视| 亚洲欧洲国产精品| 亚洲一区www| 精品视频在线播放色网色视频| 亚洲国产91精品在线观看| 国产精品一区=区| 亚洲已满18点击进入在线看片| 国产suv精品一区二区| 久久国产视频网站| 亚洲国产高清高潮精品美女| 成人黄在线观看| 国产欧美日韩专区发布| 中文字幕日韩精品在线| 国产精品久久久久久网站| 成人黄色av免费在线观看| 热门国产精品亚洲第一区在线| 亚洲国产中文字幕在线观看| 日韩免费观看在线观看| 久久久精品视频在线观看| 久久免费在线观看| 亚洲免费中文字幕| 亚洲人永久免费| 成人黄色av播放免费| 久久久久久久久久久网站| 亚洲第一免费播放区| 精品欧美一区二区三区| 日韩av在线免费| 91九色综合久久| 亚洲成在人线av| 欧美日韩美女视频| 日本久久久久亚洲中字幕| 国产91在线播放精品91| 亚洲国产精品成人va在线观看| 久久久久国产精品www| 亚洲欧美一区二区激情| 国产精品国产三级国产aⅴ9色| 日韩av在线不卡| 欧美尤物巨大精品爽| 成人免费黄色网| 国产做受高潮69| 亚洲精品欧美极品| 理论片在线不卡免费观看| 国产成人精品免高潮在线观看| 国产精品久久综合av爱欲tv| 最近的2019中文字幕免费一页| 国内精品400部情侣激情| 欧美性xxxxxxxxx| 国产精品视频yy9099| **欧美日韩vr在线| 欧美亚洲成人xxx| 国产精品无码专区在线观看| 欧美激情综合色综合啪啪五月| 亚洲欧洲视频在线| 国产精品福利在线观看| 26uuu另类亚洲欧美日本老年| 欧美日在线观看| 久久精品国产清自在天天线| 九九热视频这里只有精品| 6080yy精品一区二区三区| 久久精品一偷一偷国产| 国产一区二区三区丝袜| 色婷婷**av毛片一区| 国产一区二区三区在线免费观看| 91在线无精精品一区二区| 亚洲人成啪啪网站| 国产精品久久精品| 性金发美女69hd大尺寸| 日韩av毛片网| 国产成人综合久久| 久久精品一偷一偷国产| 免费不卡欧美自拍视频| 欧美电影免费观看高清| 亚洲第一精品夜夜躁人人爽| 欧美精品videos另类日本| 国产婷婷97碰碰久久人人蜜臀| 欧美孕妇毛茸茸xxxx| 国产精品稀缺呦系列在线| 亚洲精品小视频| 久久电影一区二区| 国内成人精品视频| 国产日韩综合一区二区性色av| 国产做受69高潮| 亚洲精品99久久久久中文字幕| 久久久久国色av免费观看性色| 日韩欧美a级成人黄色| 亚洲精品720p| 国产成人一区二区| zzjj国产精品一区二区| 亚洲aaa激情| 91精品视频在线免费观看| 亚洲国产精品久久精品怡红院| 国产精品三级在线| 国产午夜精品免费一区二区三区| 精品福利在线视频| 九九热最新视频//这里只有精品| 97免费在线视频| 91精品久久久久久| 日韩成人在线视频网站| 欧美性生交大片免费| 91精品国产沙发| 欧美日韩国产精品一区| 亚洲sss综合天堂久久| 日韩综合视频在线观看| 国产日韩欧美电影在线观看| 亚洲色图综合网| 欧美日韩一区二区三区| 亚洲午夜av电影| 欧美激情喷水视频| 国产女同一区二区| 亚洲欧美成人精品| 欧美精品中文字幕一区| 97免费在线视频| 亚洲第一色中文字幕| 北条麻妃一区二区在线观看| 国产精品自产拍高潮在线观看| 日韩美女免费视频| xvideos国产精品| 亚洲午夜av电影|