亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Species Tree如何使用HashTable實現

發布時間:2021-07-01 12:01:03 來源:億速云 閱讀:124 作者:小新 欄目:編程語言

這篇文章主要介紹了Species Tree如何使用HashTable實現,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

Species Tree 利用HashTable實現

題目再現

題目內容:

給定一個物種演化圖,
關系的表示方式如下:
x y : 表示x為y的先祖。
一個物種只會有一個先祖,
一個先祖可以有很多個演化出來的物種,
請你找出每個問題詢問物種的祖父物種(先祖的先祖),
每個物種會使用一個不重復的編號來表示,
如果該物種沒有祖父物種的話或是不存在,
那么請將他的祖父物種當是0。(憑空而生)
保證所有物種間一定有所關連,
且不會有重復演化的現象發生,
即演化圖只會是一棵樹。

輸入格式:
只有一組測資。
第一行會有兩個數字N、Q,代表總共有N個物種及Q個問題。
接下來N-1行,每一行有兩個數字x、y,
意義如題目所述。
接下來的Q行,每一行有一個數字Z,
代表要詢問的物種編號。
測資范圍:
1 < N < 10000
0 < Q < 1000
0 < x, y, z < 1000000

輸出格式:
對于每一個詢問的物種編號,將他們的祖父物種編號加總后再輸出。

輸入樣例:
6 3
1000 2000
1000 3000
2000 4000
3000 5000
5000 6000
5000
6000
1234

輸出樣例:
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 -1

typedef 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;
}

感謝你能夠認真閱讀完這篇文章,希望小編分享的“Species Tree如何使用HashTable實現”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

虎林市| 章丘市| 长宁区| 青神县| 合阳县| 梁平县| 黑山县| 永登县| 额济纳旗| 新巴尔虎左旗| 顺义区| 河池市| 虎林市| 纳雍县| 鄂伦春自治旗| 白山市| 揭西县| 调兵山市| 靖安县| 罗田县| 沛县| 江山市| 保靖县| 石嘴山市| 大连市| 包头市| 达拉特旗| 余姚市| 翁牛特旗| 阿尔山市| 宁城县| 平利县| 东莞市| 社旗县| 灌南县| 彩票| 吉安市| 敦煌市| 临桂县| 洮南市| 辰溪县|