Hacker News new | past | comments | ask | show | jobs | submit login

Sorting or hashing are the main ways to:

- construct sets

- remove duplicates

- construct and query dictionaries (especially multi-maps, btrees, etc)

- group equivalent elements

- find the number of occurrences

- etc

Hashing solutions tend to be popular in modern language standard libraries, but not in C or C++ where in-place algorithms and simpler implementations are preferred. You could also make the argument that it's much harder to use hashes with generics as it's not always clear how to define good hashes for complex data types. Alternatively, sort requires only a < implementation.

> bucket sort which you could say runs in linear time.

This only works for integers in a small range. Also consider strings, doubles, or lexicographically ordered arrays.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: