代码拉取完成,页面将自动刷新
const readlineSync = require('readline-sync');
// 计算信源熵的函数
function calculateEntropy(probabilities) {
let entropy = 0;
for (let p of probabilities) {
if (p > 0) {
entropy -= p * Math.log2(p); // 计算熵的公式
}
}
return entropy;
}
// 解析输入并进行验证的函数
function parseInput(input) {
let probabilities = input.split(/[, ]+/).map(Number); // 支持空格或逗号分隔
let sum = probabilities.reduce((a, b) => a + b, 0);
// 验证输入是否合法
if (probabilities.some(isNaN)) {
console.error("输入无效!请输入有效的数字。");
process.exit(1);
}
if (probabilities.some(p => p < 0 || p > 1)) {
console.error("概率必须在 0 和 1 之间!");
process.exit(1);
}
if (sum !== 1) {
console.error("概率总和必须为 1!");
process.exit(1);
}
return probabilities;
}
// 获取用户输入的概率分布
function getUserInput() {
console.log("请输入信源概率分布: (Ctrl+D 退出输入)");
let input = readlineSync.question();
return parseInput(input);
}
// 主程序逻辑
function main() {
let probabilities;
if (process.argv.length > 2) {
const input = process.argv.slice(2).join(' ');
probabilities = parseInput(input);
} else {
probabilities = getUserInput();
}
console.log(`p = [${probabilities.join(',')}]`);
console.log(`h(p) = ${calculateEntropy(probabilities).toFixed(3)} bit`);
}
// 运行程序
main();
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。