一伐木工为保护生态环境,每次砍树时只选定一高度在森林伐树。如设定高度为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
c求砍树高度,实在是想不出来
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
2条回答 默认 最新
CSDN专家-link 2021-08-05 14:07关注代码写好了
#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; }本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报解决 2无用