function [isPerm, msg] = check_permutation_matrix(P)
% CHECK_PERMUTATION_MATRIX 判断矩阵 P 是否为严格的置换矩阵
% 输入: P - 待检测矩阵
% 输出: isPerm - 布尔值 (true/false)
%       msg - 具体的失败原因 (字符串)

    isPerm = false; % 默认它是错的，通过所有检查才变真


    % 1. 检查是否为方阵
    [rows, cols] = size(P);
    if rows ~= cols
        msg = '矩阵不是方阵 (Not a square matrix)';
        return;
    end

    % 2. 检查元素是否仅包含 0 和 1
    % 注意：这里允许逻辑类型或数值类型的 0/1
    if ~all(P(:) == 0 | P(:) == 1)
        msg = '矩阵包含非 0/1 元素, 不是置换矩阵';
        return;
    end

    % 3. 检查行和是否全为 1
    if ~all(sum(P, 2) == 1)
        msg = '存在某行的和不等于 1, 不是置换矩阵';
        return;
    end

    % 4. 检查列和是否全为 1
    if ~all(sum(P, 1) == 1)
        msg = '存在某列的和不等于 1, 不是置换矩阵';
        return;
    end

    % 如果通过所有检查
    isPerm = true;
    msg = '是置换矩阵';
end