Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ค้นหาจุดพาร์ติชั่นในอาร์เรย์ใน C++


ในบทช่วยสอนนี้ เราจะค้นหาจุดพาร์ติชั่นในอาร์เรย์โดยที่องค์ประกอบทั้งหมดที่เหลือจนถึงจุดพาร์ติชั่นมีขนาดเล็ก และองค์ประกอบทั้งหมดทางด้านขวาจนถึงจุดพาร์ติชั่นนั้นใหญ่

มาดูขั้นตอนการแก้ปัญหากัน

  • เริ่มต้นอาร์เรย์

  • วนซ้ำบนอาร์เรย์

    • วนซ้ำจาก 0 ถึง I และตรวจสอบแต่ละค่าว่ามีค่าน้อยกว่าค่าปัจจุบันหรือไม่

    • วนซ้ำจาก I ถึง n และตรวจสอบแต่ละค่าว่ามีค่ามากกว่าค่าปัจจุบันหรือไม่

    • หากบอทตรงตามเงื่อนไขก็คืนค่ามา

  • พิมพ์จุดแบ่งพาร์ติชัน

ตัวอย่าง

มาดูโค้ดกันเลย

#include <bits/stdc++.h>
using namespace std;
int findPartitionElement(int arr[], int n) {
   for (int i = 0; i < n; i++) {
      int is_found = true;
      for (int j = 0; j < i; j++) {
         if (arr[j] >= arr[i]) {
            is_found = false;
            break;
         }
      }
      for (int j = i + 1; j < n; j++) {
         if (arr[j] <= arr[i]) {
            is_found = false;
            break;
         }
      }
      if (is_found) {
         return arr[i];
      }
   }
   return -1;
}
int main() {
   int arr[] = { 4, 3, 5, 6, 7 };
   cout << findPartitionElement(arr, 5) << endl;
   return 0;
}

ผลลัพธ์

หากคุณรันโค้ดด้านบน คุณจะได้ผลลัพธ์ดังต่อไปนี้

5

บทสรุป

หากคุณมีข้อสงสัยใดๆ ในบทแนะนำ โปรดระบุในส่วนความคิดเห็น