function [c_perm] = RandPermDistN(m,c_dist)
c_perm = 1:m;
if c_dist <= 0 
    return ;
end
while 1
    
    r = randi(m-1)+1;
    i = randi(r-1);
    while i+1 <= r
        j = i+1;
        if c_perm(i) < c_perm(j)
            t_perm = c_perm;
            gg = t_perm(i);
            t_perm(i) = t_perm(j);
            t_perm(j) = gg;
            c_perm = t_perm;
            c_dist = c_dist-1;
        end
        if c_dist <= 0 
            return ;
        end
        i = i+1;
    end
   
end

