huffman-coding sorting-algorithms brute-force dynamic-programming greedy-algorithms knapsack-problem kruskal-algorithm prims-algorithm algorithms-and-data-structures travelling-salesman-problem knuth-morris-prat