hello-algo/zh-hant/codes/swift/chapter_hashing/array_hash_map.swift

111 lines
2.7 KiB
Swift
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/**
* File: array_hash_map.swift
* Created Time: 2023-01-16
* Author: nuomi1 (nuomi1@qq.com)
*/
import utils
/* */
class ArrayHashMap {
private var buckets: [Pair?]
init() {
// 100
buckets = Array(repeating: nil, count: 100)
}
/* */
private func hashFunc(key: Int) -> Int {
let index = key % 100
return index
}
/* */
func get(key: Int) -> String? {
let index = hashFunc(key: key)
let pair = buckets[index]
return pair?.val
}
/* */
func put(key: Int, val: String) {
let pair = Pair(key: key, val: val)
let index = hashFunc(key: key)
buckets[index] = pair
}
/* */
func remove(key: Int) {
let index = hashFunc(key: key)
// nil
buckets[index] = nil
}
/* */
func pairSet() -> [Pair] {
buckets.compactMap { $0 }
}
/* */
func keySet() -> [Int] {
buckets.compactMap { $0?.key }
}
/* */
func valueSet() -> [String] {
buckets.compactMap { $0?.val }
}
/* */
func print() {
for pair in pairSet() {
Swift.print("\(pair.key) -> \(pair.val)")
}
}
}
@main
enum _ArrayHashMap {
/* Driver Code */
static func main() {
/* */
let map = ArrayHashMap()
/* */
// (key, value)
map.put(key: 12836, val: "小哈")
map.put(key: 15937, val: "小囉")
map.put(key: 16750, val: "小算")
map.put(key: 13276, val: "小法")
map.put(key: 10583, val: "小鴨")
print("\n新增完成後,雜湊表為\nKey -> Value")
map.print()
/* */
// key value
let name = map.get(key: 15937)!
print("\n輸入學號 15937 ,查詢到姓名 \(name)")
/* */
// (key, value)
map.remove(key: 10583)
print("\n刪除 10583 後,雜湊表為\nKey -> Value")
map.print()
/* */
print("\n走訪鍵值對 Key->Value")
for pair in map.pairSet() {
print("\(pair.key) -> \(pair.val)")
}
print("\n單獨走訪鍵 Key")
for key in map.keySet() {
print(key)
}
print("\n單獨走訪值 Value")
for val in map.valueSet() {
print(val)
}
}
}