在C ++中查找给定圆的两个部分的最小角度差的程序
在本教程中,我们将讨论一个程序,以找到给定圆的两个部分的最小角度差。
为此,我们将提供分为n个部分的圆。我们的任务是将这两部分组合成两部分,以使这两部分所成角度的差异最小。
示例
#include <bits/stdc++.h>
using namespace std;
//返回最小差异
int findMinimumAngle(int arr[], int n) {
int l = 0, sum = 0, ans = 360;
for (int i = 0; i < n; i++) {
sum += arr[i];
while (sum >= 180) {
ans = min(ans, 2 * abs(180 - sum));
sum -= arr[l];
l++;
}
ans = min(ans, 2 * abs(180 - sum));
}
return ans;
}
int main() {
int arr[] = { 100, 100, 160 };
int n = sizeof(arr) / sizeof(arr[0]);
cout << findMinimumAngle(arr, n) << endl;
return 0;
}输出结果
40
热门推荐
10 18岁祝福语搞笑简短
11 拥有爱的祝福语简短
12 国庆中秋祝福语简短搞笑
13 对女友的简短祝福语
14 买房的祝福语高级简短
15 男士送花祝福语大全简短
16 喜得新房文案祝福语简短
17 美好的成语祝福语简短
18 给干爸过年祝福语简短