国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - C/C++ - Species Tree 利用HashTable實現實例代碼

Species Tree 利用HashTable實現實例代碼

2021-04-28 14:40C語言教程網 C/C++

這篇文章主要介紹了Species Tree 利用HashTable實現實例代碼的相關資料,需要的朋友可以參考下

Species Tree 利用HashTable實現

題目再現

題目內容:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
給定一個物種演化圖,
關系的表示方式如下:
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),但是空間上就會浪費比較多了。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#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表實現。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
#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占用的小)

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#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;
}

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

延伸 · 閱讀

精彩推薦
  • C/C++學習C++編程的必備軟件

    學習C++編程的必備軟件

    本文給大家分享的是作者在學習使用C++進行編程的時候所用到的一些常用的軟件,這里推薦給大家...

    謝恩銘10102021-05-08
  • C/C++C語言中炫酷的文件操作實例詳解

    C語言中炫酷的文件操作實例詳解

    內存中的數據都是暫時的,當程序結束時,它們都將丟失,為了永久性的保存大量的數據,C語言提供了對文件的操作,這篇文章主要給大家介紹了關于C語言中文件...

    針眼_6702022-01-24
  • C/C++C語言實現電腦關機程序

    C語言實現電腦關機程序

    這篇文章主要為大家詳細介紹了C語言實現電腦關機程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    xiaocaidayong8482021-08-20
  • C/C++C++之重載 重定義與重寫用法詳解

    C++之重載 重定義與重寫用法詳解

    這篇文章主要介紹了C++之重載 重定義與重寫用法詳解,本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下...

    青山的青6062022-01-04
  • C/C++深入理解goto語句的替代實現方式分析

    深入理解goto語句的替代實現方式分析

    本篇文章是對goto語句的替代實現方式進行了詳細的分析介紹,需要的朋友參考下...

    C語言教程網7342020-12-03
  • C/C++C/C++經典實例之模擬計算器示例代碼

    C/C++經典實例之模擬計算器示例代碼

    最近在看到的一個需求,本以為比較簡單,但花了不少時間,所以下面這篇文章主要給大家介紹了關于C/C++經典實例之模擬計算器的相關資料,文中通過示...

    jia150610152021-06-07
  • C/C++詳解c語言中的 strcpy和strncpy字符串函數使用

    詳解c語言中的 strcpy和strncpy字符串函數使用

    strcpy 和strcnpy函數是字符串復制函數。接下來通過本文給大家介紹c語言中的strcpy和strncpy字符串函數使用,感興趣的朋友跟隨小編要求看看吧...

    spring-go5642021-07-02
  • C/C++c++ 單線程實現同時監聽多個端口

    c++ 單線程實現同時監聽多個端口

    這篇文章主要介紹了c++ 單線程實現同時監聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下...

    源之緣11542021-10-27
主站蜘蛛池模板: 亚洲国产二区 | 久久精品一区二区三区四区 | 中文字幕91在线 | 毛片真人毛毛片毛片 | 欧美在线小视频 | 人人爱人人爽 | 亚洲精品在线视频 | 久久精品成人免费视频 | 中文字幕在线观看视频地址二 | 精品动漫一区 | 青青久久久 | 亚洲欧美日韩在线 | 欧美日韩国产三级 | 成人影院www在线观看 | 97超碰免费 | 北条麻妃在线一区二区免费播放 | 黄色网页在线观看 | 国产在线精品一区 | 亚洲一区二区视频 | 999精品嫩草久久久久久99 | 国产一区日韩欧美 | 亚洲天堂一区 | 欧美一区二区最爽乱淫视频免费看 | 欧美午夜精品久久久久久浪潮 | 成人国产综合 | 亚洲一区二区中文字幕 | 久久久久国产精品 | 成年人免费在线观看视频网站 | 久久老妇| 欧美日韩中文字幕 | 91久久精品 | 欧产日产国产一区 | 亚洲xx视频| 在线观看亚洲a | 天天久久 | 精品在线视频播放 | 成人在线网站 | 午夜影视免费观看 | 久久综合九九 | 九九精品视频在线观看 | 人人澡人人射 |