mirror of
http://bgp.hk.skcks.cn:10086/https://github.com/krahets/hello-algo
synced 2026-04-20 21:00:58 +08:00
Some checks failed
C / build (Release, cl, codes/c, cl, windows-latest) (push) Has been cancelled
C / build (Release, cl, en/codes/c, cl, windows-latest) (push) Has been cancelled
C / build (Release, clang, codes/c, clang++, ubuntu-latest) (push) Has been cancelled
C / build (Release, clang, en/codes/c, clang++, ubuntu-latest) (push) Has been cancelled
C / build (Release, gcc, codes/c, g++, ubuntu-latest) (push) Has been cancelled
C / build (Release, gcc, en/codes/c, g++, ubuntu-latest) (push) Has been cancelled
C++ / build (Release, cl, codes/cpp, cl, windows-latest) (push) Has been cancelled
C++ / build (Release, cl, en/codes/cpp, cl, windows-latest) (push) Has been cancelled
C++ / build (Release, clang, codes/cpp, clang++, ubuntu-latest) (push) Has been cancelled
C++ / build (Release, clang, en/codes/cpp, clang++, ubuntu-latest) (push) Has been cancelled
C++ / build (Release, gcc, codes/cpp, g++, ubuntu-latest) (push) Has been cancelled
C++ / build (Release, gcc, en/codes/cpp, g++, ubuntu-latest) (push) Has been cancelled
Dart / Dart stable on macos-latest (push) Has been cancelled
Dart / Dart stable on ubuntu-latest (push) Has been cancelled
Dart / Dart stable on windows-latest (push) Has been cancelled
.NET / .NET 8.0.x on macos-latest (push) Has been cancelled
.NET / .NET 8.0.x on ubuntu-latest (push) Has been cancelled
.NET / .NET 8.0.x on windows-latest (push) Has been cancelled
Go / Go 1.19.x on macos-latest (push) Has been cancelled
Go / Go 1.19.x on ubuntu-latest (push) Has been cancelled
Go / Go 1.19.x on windows-latest (push) Has been cancelled
Java / Java 11 sample (push) Has been cancelled
Java / Java 17 sample (push) Has been cancelled
JavaScript / build (codes/javascript, macos-latest) (push) Has been cancelled
JavaScript / build (codes/javascript, ubuntu-latest) (push) Has been cancelled
JavaScript / build (codes/javascript, windows-latest) (push) Has been cancelled
JavaScript / build (en/codes/javascript, macos-latest) (push) Has been cancelled
JavaScript / build (en/codes/javascript, ubuntu-latest) (push) Has been cancelled
JavaScript / build (en/codes/javascript, windows-latest) (push) Has been cancelled
Kotlin / Kotlin on macos-latest (push) Has been cancelled
Kotlin / Kotlin on ubuntu-latest (push) Has been cancelled
Python / Python 3.10 on macos-latest (push) Has been cancelled
Python / Python 3.10 on ubuntu-latest (push) Has been cancelled
Python / Python 3.10 on windows-latest (push) Has been cancelled
Ruby / Ruby 3.3 on macos-latest (push) Has been cancelled
Ruby / Ruby 3.3 on ubuntu-latest (push) Has been cancelled
Ruby / Ruby 3.3 on windows-latest (push) Has been cancelled
Rust / build (codes/rust, macos-latest) (push) Has been cancelled
Rust / build (codes/rust, ubuntu-latest) (push) Has been cancelled
Rust / build (codes/rust, windows-latest) (push) Has been cancelled
Rust / build (en/codes/rust, macos-latest) (push) Has been cancelled
Rust / build (en/codes/rust, ubuntu-latest) (push) Has been cancelled
Rust / build (en/codes/rust, windows-latest) (push) Has been cancelled
Swift / Swift on macos-14 (push) Has been cancelled
Swift / Swift on ubuntu-22.04 (push) Has been cancelled
TypeScript / build (codes/typescript, macos-latest) (push) Has been cancelled
TypeScript / build (codes/typescript, ubuntu-latest) (push) Has been cancelled
TypeScript / build (codes/typescript, windows-latest) (push) Has been cancelled
TypeScript / build (en/codes/typescript, macos-latest) (push) Has been cancelled
TypeScript / build (en/codes/typescript, ubuntu-latest) (push) Has been cancelled
TypeScript / build (en/codes/typescript, windows-latest) (push) Has been cancelled
* Review the EN heading format. * Fix pythontutor headings. * Fix pythontutor headings. * bug fixes * Fix headings in **/summary.md * Revisit the CN-to-EN translation for Python code using Claude-4.5 * Revisit the CN-to-EN translation for Java code using Claude-4.5 * Revisit the CN-to-EN translation for Cpp code using Claude-4.5. * Fix the dictionary. * Fix cpp code translation for the multipart strings. * Translate Go code to English. * Update workflows to test EN code. * Add EN translation for C. * Add EN translation for CSharp. * Add EN translation for Swift. * Trigger the CI check. * Revert. * Update en/hash_map.md * Add the EN version of Dart code. * Add the EN version of Kotlin code. * Add missing code files. * Add the EN version of JavaScript code. * Add the EN version of TypeScript code. * Fix the workflows. * Add the EN version of Ruby code. * Add the EN version of Rust code. * Update the CI check for the English version code. * Update Python CI check. * Fix cmakelists for en/C code. * Fix Ruby comments
1.2 KiB
1.2 KiB
小结
重点回顾
- 二分查找依赖数据的有序性,通过循环逐步缩减一半搜索区间来进行查找。它要求输入数据有序,且仅适用于数组或基于数组实现的数据结构。
- 暴力搜索通过遍历数据结构来定位数据。线性搜索适用于数组和链表,广度优先搜索和深度优先搜索适用于图和树。此类算法通用性好,无须对数据进行预处理,但时间复杂度
O(n)较高。 - 哈希查找、树查找和二分查找属于高效搜索方法,可在特定数据结构中快速定位目标元素。此类算法效率高,时间复杂度可达
O(\log n)甚至O(1),但通常需要借助额外数据结构。 - 实际中,我们需要对数据规模、搜索性能要求、数据查询和更新频率等因素进行具体分析,从而选择合适的搜索方法。
- 线性搜索适用于小型或频繁更新的数据;二分查找适用于大型、排序的数据;哈希查找适用于对查询效率要求较高且无须范围查询的数据;树查找适用于需要维护顺序和支持范围查询的大型动态数据。
- 用哈希查找替换线性查找是一种常用的优化运行时间的策略,可将时间复杂度从
O(n)降至O(1)。