一伐木工为保护生态环境,每次砍树时只选定一高度在森林伐树。如设定高度为10米,则在一排高度分别为11、15、8、25、10的树中,高于10米的部分将被砍下,所以最终会获得1+5+15=21米长的木材。为获得足够长度的木材同时又能达到保护环境的目的,需要找到每次对应的伐木高度。
输入:2个整数n和mn表示树木的数量(1≤n≤255或更高),m表示需要的木材长度(1≤m≤65535)n颗树各自高度,每棵树高度不得大于m且和必须大于m
输出:砍树的高度
例:
输入:5 20
42 26 46 40 4
输出:36
代码写好了
#include <stdio.h>
#include <stdlib.h>
int main()
{
int tree[100];
int n,m,i,j,count = 0,max=0;
scanf("%d%d",&n,&m);
for(i=0;i<n;i++)
scanf("%d",&tree[i]);
for(i=0;i<n-1;i++)
for(j=0;j<n-i-1;j++)
{
if(tree[j] < tree[j+1])
{
int k = tree[j];
tree[j] = tree[j+1];
tree[j+1] = k;
}
}
while(count < m)
{
max = tree[0];
if(max == 0)
break;
for(i=0;i<n;i++)
{
if(tree[i] == max)
{
count++;
tree[i]--;
}
else
break;
}
}
if(max == 0)
printf("树的高度不够啊\n");
printf("树的剩余高度为:%d\n",tree[0]);
return 0;
}
没看懂
每棵树高度不得大于m且和必须大于m
那为啥m=20,但第二行大部分都大于20呢?