Back to 课程

Computer-science_A-level_Cie

0% Complete
0/0 Steps
  1. computers-and-components
    6 主题
  2. logic-gates-and-logic-circuits
    2 主题
  3. central-processing-unit-cpu-architecture
    6 主题
  4. assembly-language-
    4 主题
  5. bit-manipulation
    1 主题
  6. operating-systems
    3 主题
  7. language-translators
    2 主题
  8. data-security
    3 主题
  9. data-integrity
    1 主题
  10. ethics-and-ownership
    3 主题
  11. database-concepts
    3 主题
  12. database-management-systems-dbms-
    1 主题
  13. data-definition-language-ddl-and-data-manipulation-language-dml
    1 主题
  14. computational-thinking-skills
    1 主题
  15. algorithms
    14 主题
  16. data-types-and-records
    2 主题
  17. arrays
    2 主题
  18. files
    1 主题
  19. introduction-to-abstract-data-types-adt
    1 主题
  20. programming-basics
    1 主题
  21. constructs
    2 主题
  22. structured-programming
    1 主题
  23. program-development-life-cycle
    2 主题
  24. program-design-
    2 主题
  25. program-testing-and-maintenance
    3 主题
  26. user-defined-data-types
    1 主题
  27. file-organisation-and-access-
    3 主题
  28. floating-point-numbers-representation-and-manipulation
    3 主题
  29. protocols
    2 主题
  30. circuit-switching-packet-switching
    1 主题
  31. processors-parallel-processing-and-virtual-machines
    5 主题
  32. boolean-algebra-and-logic-circuits
    4 主题
  33. purposes-of-an-operating-system-os
    3 主题
  34. translation-software
    3 主题
  35. encryption-encryption-protocols-and-digital-certificates
    3 主题
  36. artificial-intelligence-ai
    4 主题
  37. recursion
    1 主题
  38. programming-paradigms
    4 主题
  39. object-oriented-programming
    7 主题
  40. file-processing-and-exception-handling
    2 主题
  41. data-representation
    5 主题
  42. multimedia
    3 主题
  43. compression
    2 主题
  44. networks-and-the-internet
    11 主题
课 Progress
0% Complete

Hashing algorithms

What is a hashing algorithm?

  • A hashing algorithm is used to calculate the storage location (address) of a record in a random (direct access) file

  • It allows for fast access to data without searching sequentially through a file

Why use hashing?

  • Provides direct access to records using a key (e.g. ID, account number)

  • Useful when dealing with large files that need fast search, read, or write operations

  • Used in random files and sometimes in indexed sequential files

How hashing works?

  • A hashing algorithm takes a key (e.g. StudentID) and uses a mathematical function to calculate a file address

Address = HashFunction(Key)
  • If two keys produce the same address, a collision occurs

  • This must be resolved (e.g. via linear probing or overflow areas)

Writing a record to a file:

Address ← HashFunction(Key)
WRITE file[Address], Record

Reading a record from a file:

Address ← HashFunction(Key)
READ file[Address], Record
  • If the expected record is not found, collision handling must be applied to find the correct record

Types of hashing algorithms

Method

Description

Modulo Division

Most common method: Key MOD TableSize

Folding Method

Breaks the key into parts and adds them together

Mid-Square Method

Square the key and use the middle digits as the address

Multiplicative Hashing

Multiplies the key by a constant and uses fractional part × tablesize

Collision handling strategies

Strategy

Description

Linear probing

Try the next available slot in sequence

Overflow area

Store conflicting records in a separate file/area

Chaining

Store all records with the same address in a list

Responses

您的邮箱地址不会被公开。 必填项已用 * 标注