ที่นี่เราจะเห็นปัญหาหนึ่ง สมมติว่ามีหนึ่งอาร์เรย์ มี n องค์ประกอบ นอกจากนี้ยังได้รับค่า S อีก เราต้องหาองค์ประกอบ K ในอาร์เรย์ ดังนั้นหากองค์ประกอบทั้งหมดที่มากกว่า K มีค่าเท่ากับ K ผลรวมขององค์ประกอบทั้งหมดของอาร์เรย์สุดท้ายจะเท่ากับ S หากไม่สามารถทำได้ แล้วกลับ -1.
สมมติว่าองค์ประกอบคือ {12, 6, 3, 7, 8} และค่าผลรวมคือ 15 ผลลัพธ์คือ 3 อาร์เรย์สุดท้ายคือ {3, 3, 3, 3, 3} ผลรวมขององค์ประกอบอาร์เรย์คือ S =15
อัลกอริทึม
getVal(arr, n, S) −
Begin sort arr as increasing order sum := 0 for i in range 0 to n-1, do if sum + (arr[i] * (n - i)) is same as S, then return arr[i] end if sum := sum + arr[i] done return -1 End
ตัวอย่าง
#include <iostream>
#include <algorithm>
using namespace std;
int getVal(int arr[], int n, int S) {
sort(arr, arr + n);
int sum = 0;
for (int i = 0; i < n; i++) {
if (sum + (arr[i] * (n - i)) == S) //if current value is satisfying, then return arr[i]
return arr[i];
sum += arr[i];
}
return -1;
}
int main() {
int S = 15;
int arr[] = { 12, 3, 6, 7, 8 };
int n = sizeof(arr) / sizeof(arr[0]);
cout << getVal(arr, n, S);
} ผลลัพธ์
3