ที่นี่เราต้องหา GCD ของ n เงื่อนไขฟีโบนักชีด้วยดัชนีที่กำหนด ดังนั้นในตอนแรก เราต้องได้ค่าดัชนีสูงสุด และสร้างเงื่อนไข Fibonacci เงื่อนไข Fibonacci บางคำจะเป็นดังนี้:0, 1, 1, 2, 3, 5, 8, 13, 21, 34, ….. ดัชนีเริ่มต้นขึ้น จาก 0 ดังนั้นองค์ประกอบที่ 0 th ดัชนีคือ 0 หากเราต้องหา gcd ของเงื่อนไขฟีโบนักชีที่ดัชนี {2, 3, 4, 5} แล้วเทอมคือ {1, 2, 3, 4} ดังนั้น GCD ของตัวเลขเหล่านี้คือ 1
เราจะใช้แนวทางหนึ่งที่น่าสนใจในการทำภารกิจนี้ เพื่อให้ได้ GCD ของ ith และ jth Fibonacci term เช่น GCD(Fibo(i), Fibo(j)) เราสามารถแสดงออกได้เช่น Fibo(GCD(i, j))
ตัวอย่าง
#include <iostream>
#include <algorithm>
using namespace std;
int getFiboTerm(int n){
int fibo[n + 2];
fibo[0] = 0; fibo[1] = 1;
for(int i = 2; i<= n; i++){
fibo[i] = fibo[i - 1] + fibo[i - 2];
}
return fibo[n];
}
int getNFiboGCD(int arr[], int n){
int gcd = 0;
for(int i = 0; i < n; i++){
gcd = __gcd(gcd, arr[i]);
}
return getFiboTerm(gcd);
}
int main() {
int indices[] = {3, 6, 9};
int n = sizeof(indices)/sizeof(indices[0]);
cout << "GCD of fibo terms using indices: " <<
getNFiboGCD(indices, n);
} ผลลัพธ์
GCD of fibo terms using indices: 2