实验目的
1)了解分治策略算法思想及基本原理;
2)掌握使用分治算法求解问题的一般特征;
3)掌握分解、治理的方法;
4)能够针对实际问题,能够正确的分解、治理,设计分治算法;
5)能够正确分析算法的时间复杂度和空间复杂度。
实验内容(要求)
给出n个数,利用分治法求n个数中的最小值。
算法设计(问题分析、建模、算法描述)
分析:
用分治思想,把大问题划分为一个个小问题分别解决。
算法描述:
将n个数均分为s1和s2两部分,分别求解s1和s2的最小值分别为min1和min2,计算min(min1,min2)。
算法源码
#include<bits/stdc++.h>
#pragma GCC optimize(2)
#define int long long
using namespace std;
const int N = 2e5 + 10;
int n, a[N], x;
void mmin(int a[], int l, int r, int &x)
{
int mid = (l + r) / 2;
int x1, x2;
if (l == r) //只有一个数的情况
{
x = a[l];
return;
}
//分治
mmin(a, l, mid, x1);
mmin(a, mid + 1, r, x2);
x = min (x1, x2); //合并
}
int32_t main()
{
cin >> n;
for (int i = 0; i < n; ++i) {
cin >> a[i];
}
mmin(a, 0, n - 1, x);
cout << x << endl;
return 0;
}
测试数据及运算结果(要求:截图说明算法运行的结果)
测试数据1:
9
56 82 67 88 666 88 26 89 212
输出结果:
测试数据2:
8
-1 6 9 -7 5 2 1 0
输出结果:
算法分析(分析算法的时间复杂度和空间复杂度)
时间复杂度:O(n)
对于mmin()函数,其比较次数的递推式为:T(1)=T(2)=1,T(n)=2T(n/2)+1,合并的时间为O(1),可以推导出T(n)=O(n)。
空间复杂度:O(n)
使用一个长度为n的辅助数组。