ในปัญหานี้ เราจะได้รับอาร์เรย์ งานของเราคือสร้างโปรแกรมที่จะหาผลรวมแฝดสูงสุดในอาร์เรย์ นั่นคือ ค้นหาชุดขององค์ประกอบสามตัวที่ผลรวมสูงสุด
มาดูตัวอย่างเพื่อทำความเข้าใจปัญหากัน
ป้อนข้อมูล − อาร์เรย์ ={4, 6, 1, 2}
ผลผลิต − 12
คำอธิบาย −
all triplets are : (4, 6, 1) = 4+6+1 = 11 (4, 6, 2) = 4+6+1 = 12 (4, 1, 2) = 4+6+1 = 7 (6, 1, 2) = 4+6+1 = 9 The maximum triplet sum is 12
วิธีง่ายๆ วิธีหนึ่งในการแก้ปัญหาคือสิ่งที่เราได้อธิบายไว้ในตัวอย่าง ซึ่งก็คือการนำค่าผลรวมสำหรับคู่แฝดสามทั้งหมดแล้วหาค่าสูงสุดของคู่นั้น แต่วิธีนี้ไม่ได้ผลเนื่องจากความยาวของแฝดสามจะมาก
ในวิธีนี้ เราจะเรียกใช้สามลูปที่จะค้นหาผลรวมแฝดที่เป็นไปได้ทั้งหมด และหากผลรวมของแฝดสามนี้มากกว่าค่า maxsum เราจะเริ่มต้นผลรวมแฝดนี้เป็นค่าสูงสุด
ตัวอย่าง
โปรแกรมเพื่อแสดงโซลูชันของเรา
#include <iostream> using namespace std; int maxSum(int arr[], int n){ int maxSum = 0; int i, j, k; for (i = 0; i < n; i++) for (j = i + 1; j < n; j++) for (k = j + 1; k < n; k++) if (maxSum < arr[i] + arr[j] + arr[k]) maxSum = arr[i] + arr[j] + arr[k]; return maxSum; } int main(){ int arr[] = { 3, 5, 7 ,1, 9, 0 }; int n = sizeof(arr) / sizeof(arr[0]); cout<<"The maximum triplet sum of the array is "<<maxSum(arr, n); return 0; }
ผลลัพธ์
The maximum triplet sum of the array is 21
วิธีที่มีประสิทธิภาพคือการเรียงลำดับอาร์เรย์แล้วค้นหาผลรวมขององค์ประกอบสามตัวสุดท้ายของอาร์เรย์ซึ่งจะเป็นผลรวมสูงสุดของแฝดสาม
ตัวอย่าง
โปรแกรมเพื่อแสดงวิธีแก้ปัญหา
#include <bits/stdc++.h> using namespace std; int maxSum(int arr[], int n) { sort(arr, arr + n); return arr[n - 1] + arr[n - 2] + arr[n - 3]; } int main() { int arr[] = { 3, 5, 9, 1, 2, 8, 7 }; int n = sizeof(arr) / sizeof(arr[0]); cout<<"The maximum triplet sum of the array is "<<maxSum(arr, n); return 0; }
ผลลัพธ์
The maximum triplet sum of the array is 24