编程题

(切割绳子)有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;

}

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论