พิจารณาว่าเรามีอาร์เรย์ A และจำนวนเต็ม K และ M อีกสองจำนวน เราต้องหาองค์ประกอบขั้นต่ำ Kth หลังจากเชื่อมอาร์เรย์เข้ากับตัวเอง M จำนวนครั้ง สมมติว่าอาร์เรย์เป็นเหมือน A =[3, 1, 2], K =4 และ M =3 ดังนั้นหลังจากเชื่อม A แล้ว 3 ครั้ง มันจะเป็น [3, 1, 2, 3, 1, 2, 3, 1 , 2], องค์ประกอบที่เล็กที่สุดที่ 4 คือ 2 ที่นี่.
ในการแก้ปัญหานี้ เราจะจัดเรียงอาร์เรย์ A จากนั้นคืนค่าที่แสดงที่ดัชนี ((K – 1)/M) ของอาร์เรย์
ตัวอย่าง
#include<iostream> #include<algorithm> using namespace std; int findKSmallestNumber(int A[], int N, int M, int K) { sort(A, A + N); return (A[((K - 1) / M)]); } int main() { int A[] = { 3, 1, 2 }; int M = 3, K = 4; int N = sizeof(A) / sizeof(A[0]); cout << K << "th smallest number after concatenating " << M << " times, is: "<<findKSmallestNumber(A, N, M, K); }
ผลลัพธ์
4th smallest number after concatenating 3 times, is: 2