Muhammad Al-Xorazmiy nomidagi Toshkent axborot texnologiyalari universiteti Nurafshon filiali Ma’lumotlar tuzilmasi va algoritmLARI fanidan 10-11-12 mavzular yuzasidan amaliyot topshiriqlari
Bajardi: 210-22 guruh Talabasi:Abdug’aniyev Azizbek Akmaljon o’g’li Tekshirdi: Karimov Sodiqjon Toshkent -2023 10-mavzu: Daraxtsimon maʻlumotlar tuzilmalarini qayta ishlash algoritmlari va dasturlarini tuzish.
#include using namespace std; int main(){ int a[3] = {}, i; cout << "Qo'shishdan oldingi massiv:" << endl; for(i = 0; i < 3; i++) cout << "a[" << i <<"] = " < //axlat qiymatlarini chop etadi cout << "Elementlarni kiritish.." < cout << "Kiritilgandan keyin massiv:" << endl; // massiv qiymatlarini chop etadi for(i = 0; i < 5; i++) { a[i] = i + 2; cout << "a[" << i <<"] = " << a[i] << endl; } return 0; }
11-mavzu: Binar daraxtlar bilan ishlash algoritmlari
// C++ tilida rekursiyali Binar Qidiruv #include // Rekursiyali qidiruv funksiyasi. U massivdan // x qaysi o'rinda turganini qaytaradi, // yoki -1 int binarqidiruv(int arr[], int l, int r, int x) { if (r >= l) { int mid = l + (r - l)/2; // Agar element x ga teng bo'lsa // o'zi qaytadi if (arr[mid] == x) return mid; // Agar element x dan katta bo'lsa, // u faqat chap qismni oladi if (arr[mid] > x) return binarqidiruv(arr, l, mid-1, x); // Yoki u faqat o'ng qismni oladi return binarqidiruv(arr, mid+1, r, x); } // Bu yerga yetib keladi, qachonki // x soni massiv ichidan topilmasa return -1; } int main(void) { int arr[] = {2, 3, 4, 10, 40}; //massiv ni elementlar sonini topib olayabmiz int n = sizeof(arr)/ sizeof(arr[0]); int x = 10; int natija = binarqidiruv(arr, 0, n-1, x); (natija == -1)? printf("X soni massivni ichidan topilmadi.") : printf("X soni massivning %d - elementi.", natija); return 0; }
12-mavzu: Heap tree ko‘rinishidagi binar daraxtlar bilan ishlash algoritmlari.
// C++ da yig'ma tartiblash #include using namespace std; void heapify(int arr[], int n, int i) { // Ildiz, chap bola va o'ng bola orasida eng kattasini toping int largest = i; int left = 2 * i + 1; int right = 2 * i + 2; if (left < n && arr[left] > arr[largest]) largest = left; if (right < n && arr[right] > arr[largest]) largest = right; // Agar ildiz katta bo'lmasa, almashtiring va yig'ishni davom eting if (largest != i) { swap(arr[i], arr[largest]); heapify(arr, n, largest); } } // Uyma tartiblash uchun asosiy funktsiya void heapSort(int arr[], int n) { // Maksimal to'pni yarating for (int i = n / 2 - 1; i >= 0; i--) heapify(arr, n, i); // Heap sort for (int i = n - 1; i >= 0; i--) { swap(arr[0], arr[i]); // Ildizdagi eng yuqori elementni yana olish uchun ildiz elementini yig'ing heapify(arr, i, 0); } } //Massivni chop etish void printArray(int arr[], int n) { for (int i = 0; i < n; ++i) cout << arr[i] << " "; cout << "\n"; } // Haydovchi kodi int main() { int arr[] = {1, 12, 9, 5, 6, 10}; int n = sizeof(arr) / sizeof(arr[0]); heapSort(arr, n); cout << "Saralangan massiv \n"; printArray(arr, n); }