JavaScript PAT乙级题解 1057 数零壹

给定一串长度不超过 105 的字符串,本题要求你将其中所有英文字母的序号(字母 a-z 对应序号 1-26,不分大小写)相加,得到整数 N,然后再分析一下 N 的二进制表示中有多少 0、多少 1。例如给定字符串 PAT (Basic),其字母序号之和为:16+1+20+2+1+19+9+3=71,而 71 的二进制是 1000111,即有 3 个 0、4 个 1。

输入格式:

输入在一行中给出长度不超过 105、以回车结束的字符串。

输出格式:

在一行中先后输出 0 的个数和 1 的个数,其间以空格分隔。注意:若字符串中不存在字母,则视为 N 不存在,也就没有 0 和 1。

输入样例:

复制代码
PAT (Basic)

输出样例:

复制代码
3 4

题解如下:

20/20

先将字符串全部转成小写,遍历字符串求出每个英文字母的序号并进行累加,得到sum,再对sum进行二进制转换,判断每次求余得到的是0/1,对应变量++

javascript 复制代码
/**
 * 2024/04/08
 * 20/20
 */
const readline = require("readline");
const rl = readline.createInterface({
  input: process.stdin,
  output: process.stdout,
});

rl.on("line", function (data) {
  // 将字符串中的所有英文字母转换为小写
  data = data.toLowerCase();
  let sum = 0;
  for (let i = 0; i < data.length; i++) {
    if (data[i] >= "a" && data[i] <= "z") {
      // a的ascii码为97,从1开始排序,减96
      sum += data[i].charCodeAt(0) - 96;
    }
  }
  toBinary(sum);
  console.log(zeroNum, oneNum);
});

// 0出现的次数
let zeroNum = 0;
// 1出现的次数
let oneNum = 0;
function toBinary(data) {
  if (data !== 0) {
    if (data % 2 === 0) {
      zeroNum++;
    } else {
      oneNum++;
    }
    toBinary(Math.floor(data / 2));
  }
}
相关推荐
nvvas2 分钟前
Could not resolve “@intlify/vue-devtools‘ node modules/. pnpm/vue-118n@9. 14
前端·javascript·vue.js
人道领域10 分钟前
【LeetCode刷题日记】225.用队列实现栈--三招实现栈操作(多种思维)
java·开发语言·算法·leetcode·面试
yqcoder10 分钟前
[特殊字符] Vue 3 组件通信全指南:从基础到进阶
前端·javascript·vue.js
梦想的颜色14 分钟前
js 去掉除法后得出的小数点
javascript·vue.js
爱上好庆祝14 分钟前
学习js第一天(出发新世界)
开发语言·前端·javascript·css·学习·html·ecmascript
木斯佳16 分钟前
前端八股文面经大全:秦丝科技前端(2026-04-24)·笔试深度解析
前端·笔试
喜欢吃鱿鱼17 分钟前
VUE项目 弹窗改为页面供其他项目嵌入iframe - 截取地址栏URL中的参数
前端·javascript·vue.js
无心使然云中漫步19 分钟前
Openlayers调用ArcGis地图服务之二 —— 动态地图(/export)
前端·arcgis·vue·数据可视化
新新学长搞科研20 分钟前
【高届数机械工程会议】第十二届机械工程、材料和自动化技术国际学术会议(MMEAT 2026)
运维·人工智能·算法·机器学习·自动化·软件工程·激光
Chengbei1121 分钟前
全新开源 Burp AI 扫描插件、支持 17 类 Web检测,自带 WAF 绕过,一键自动化挖掘并智能验证
前端·人工智能·自动化