สมมติว่าเรามีอาร์เรย์ arr และค่าอื่น k เราต้องหาจำนวนการดำเนินการขั้นต่ำเพื่อให้ GCD ของอาร์เรย์เท่ากับผลคูณของ k ในกรณีนี้ การดำเนินการจะเพิ่มหรือลดค่าลง สมมติว่าอาร์เรย์เป็นเหมือน {4, 5, 6} และ k คือ 5 เราสามารถเพิ่ม 4 ได้ 1 และลด 6 ลง 1 ดังนั้นจึงกลายเป็น 5 การดำเนินการจำนวนหนึ่งคือ 2
เราต้องทำตามขั้นตอนเหล่านี้เพื่อให้ได้ผลลัพธ์ -
ขั้นตอน −
- สำหรับองค์ประกอบทั้งหมด e ในอาร์เรย์ ให้ทำตามขั้นตอนที่ 2 และ 3
- ถ้า e ไม่ใช่ 1 และ e> k ให้เพิ่มผลลัพธ์เป็นค่าต่ำสุดของ (e mod k) และ (k – e mod k)
- มิฉะนั้น ผลลัพธ์จะเป็นผลลัพธ์ + k – e
- ผลตอบแทน
ตัวอย่าง
#include <iostream> using namespace std; int countMinOp(int arr[], int n, int k) { int result = 0; for (int i = 0; i < n; ++i) { if (arr[i] != 1 && arr[i] > k) { result = result + min(arr[i] % k, k - arr[i] % k); } else { result = result + k - arr[i]; } } return result; } int main() { int arr[] = { 4, 5, 6 }; int n = sizeof(arr) / sizeof(arr[0]); int k = 5; cout << "Minimum operation required: " << countMinOp(arr, n, k); }
ผลลัพธ์
Minimum operation required: 2