(切割绳子)有n条绳子,每条绳子的长度已知且均为正整数。绳子可以以任意正整数长度切割,但不可以连接。现在要从这些绳子中切割出m条长度相同的绳段,求绳段的最大长度是多少。(第一、二空2.5分,其余3分)
输入:第一行是一个不超过100的正整数n,第二行是n个不超过106的正整数,表示每条绳子的长度,第三行是一个不超过108的正整数m。
输出:绳段的最大长度,若无法切割,输出Failed。
#include
using namespace std;
int n, m, i, lbound, ubound, mid, count;
int len[100]; // 绳子长度
int main() {
\tcin >> n;
\tcount = 0;
\tfor (i = 0; i < n; i ) {
\t\tcin >> len[i];
\t (1) ;
\t}
\tcin >> m;
\tif ( (2) ) {
\t\tcout << "Failed" << endl;
\t\treturn 0;
\t}
\tlbound = 1;
\tubound = 1000000;
\twhile ( (3) ) {
\t\tmid = (4) ;
\t\tcount = 0;
\t\tfor (i = 0; i < n; i )
\t (5) ;
\t\tif (count < m)
\t\t\tubound = mid - 1;
\t\telse
\t\t\tlbound = mid;
\t}
\tcout << lbound << endl;
\treturn 0;
}
发表评论 取消回复