数字之前的除法后数组求和?
这里我们将看到一个有趣的问题。我们将取一个数组,然后通过取数组中的每个元素并将其除以前面的元素来计算和。让我们考虑一个数组 {5, 6, 7, 2, 1, 4}。那么结果将是 5 + (6 / 5) + (7 / 6) + (2 / 7) + (1 / 2) + (4 / 1) = 12.15238。让我们看看算法以获得概念。
算法
divSum(arr, n)
begin sum := arr[0] for i := 1 to n-1, do sum := sum + arr[i] / arr[i-1] done return sum end
示例
#include <iostream> using namespace std; float divSum(int arr[], int n){ float sum = arr[0]; for(int i = 1; i<n; i++){ sum += arr[i] / float(arr[i - 1]); } return sum; } int main() { int arr[6] = {5, 6, 7, 2, 1, 4}; int n = 6; cout << "Sum : " << divSum(arr, n); }
输出
Sum : 12.1524
广告