题目描述:
(切割绳子)有 n 条绳子,每条绳子的长度已知且均为正整数。绳子可以以任意正整数长度切割,但不可以连接。现在要从这些绳子中切割出 m 条长度相同的绳段,求绳段的最大长度是多少。(第一、二空 2.5 分,其余 3 分)
输入:第一行是一个不超过 100 的正整数 n,第二行是 n 个不超过 10^6 的正整数,表示每条绳子的长度,第三行是一个不超过 10^8 的正整数 m。
输出:绳段的最大长度,若无法切割,输出 Failed。
#include <iostream>
using namespace std;
int main()
{
int n;
int m;
int i, lbound, rbound, mid, count;
int len[100]; //绳子长度
cin >> n;
count = 0;
for (i = 0; i<n; i++)
{
cin >> len[i];
count = count + len[i];//计算绳子的总长度
}
cin >> m;
if (count<m) //绳子的总长度没有要分割的段数多
{
cout << "Falied" << endl;
return 0;
}
lbound = 1; //左边界
rbound = 100; //右边界
while (lbound < rbound)
{
mid = (lbound + rbound ) / 2 + 1;
count = 0;//统计分割的段数
for (i = 0; i<n; i++)
{
count = count + len[i] / mid;
}
if (count < m)
{
rbound = mid -1;
}
else
{
lbound = mid ;
}
}
cout << lbound << endl;
//cin.get();
system("pause");
return 0;
}