Chia sẻ kiến thức ngôn ngữ lập trình C, C++, C#, Java, Python, PHP, JS, SQL ...
Các điều hành viên: Mod, SMod, Admin
#3 » gửi bởi nghiammo1992 » 13/09/2021 11:03 » @523449
Thuật toán tìm kiếm nội suy (interpolation search) (code này chỉ áp dụng cho mảng đã sắp xếp tăng dần)- Mã: Chọn tất cả
using namespace std;
int InterpolationSearch(int A[], int n, int x)
{
int left = 0;
int right = n - 1;
int mid;
while (left <= right && x >= A[left] && x <= A[right])
{
mid = left + (right - left) * (x - A[left]) / (A[right] - A[left]);
if (A[mid] == x)
return mid;
if (A[mid] > x)
right = mid - 1;
else if (A[mid] < x)
left = mid + 1;
}
return -1; }
int main()
{
int arr[] {-33,-26,-5,1,2,3,7,12,32,45,53,71,80,99,100};
int n = sizeof(arr) / sizeof(arr[0]); cout << "So luong phan tu trong mang: " << n << endl;
cout << InterpolationSearch(arr, n, -5);
return 0;
}
-
nghiammo1992
- Rank:
- Cấp độ: 💚15💚
- Tu luyện: ☀️2/30☀️
- Like: 4355/14760
- Online: ✨1/5359✨
- Bang hội: Tiếu Ngạo
- Xếp hạng Bang hội: ⚡5/46⚡
- Level: ⭐75/1227⭐
- Chủ đề đã tạo: 🩸4141/4141🩸
- Tiền mặt: 295 Xu
- Ngân hàng: 5 Xu
- Nhóm: Admin
- Danh hiệu: ⚝⚝⚝Truyền Thuyết⚝⚝⚝
- Giới tính:
- Ngày tham gia: 08/03/2012 10:56
- Đến từ: Hà Giang
- Thiết bị: Nokia N96
- Số điện thoại: 0367790762
- (Google Chrome 94.0.460)
-
Quay về C, C++, C#, Java, Python, PHP, JS, SQL ...