c求砍树高度,实在是想不出来

一伐木工为保护生态环境,每次砍树时只选定一高度在森林伐树。如设定高度为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呢?