华为机考 ------ 计算某字符出现次数

描述

对于给定的由大小写字母、数字和空格混合构成的字符串 s,给定字符 c,按要求统计:

  • 若 c为大写或者小写字母,统计其大小写形态出现的次数和
  • 若 c 为数字,统计其出现的次数

保证字符 c 要么为字母、要么为数字。

输入描述:

第一行输入一个长度 1≦length(s)≦10³,由大小写字母、数字和空格构成的字符串 s。保证首尾不为空格。

第二行输入一个字符 c,保证 c 为大小写字母或数字。

输出描述:

在一行上输出一个整数,代表统计结果。
示例1

复制代码
输入:
HELLONowcoder123
o
输出:
3
说明:
由于 o 为小写字母,因此统计其大小写形态出现的次数和,即 3。

示例2

复制代码
输入:
H E L L O Nowcoder123
1
输出:
1

解题思路

这个问题是字符统计 问题,需要根据字符 c的类型进行不同的统计:

  1. 字符类型判断

    • 如果 c是字母(大写或小写):统计这个字母的大小写形态的总出现次数

    • 如果 c是数字:只统计这个数字的出现次数

  2. 关键点

    • 输入字符串可能包含字母、数字、空格

    • 首尾保证不为空格

    • 字符 c要么是字母要么是数字

    • 字符串长度不超过 10³(1000)

  3. 处理逻辑

    • 遍历字符串的每个字符

    • 根据 c的类型进行匹配

    • 如果是字母,需要匹配不区分大小写的字符

    • 如果是数字,需要精确匹配

JavaScript 解决方案

复制代码
const readline = require('readline');

const rl = readline.createInterface({
    input: process.stdin,
    output: process.stdout
});

let inputLines = [];
let lineCount = 0;

rl.on('line', (line) => {
    inputLines.push(line);
    lineCount++;
    
    if (lineCount === 2) {
        const s = inputLines[0];  // 原始字符串
        const c = inputLines[1];  // 目标字符
        
        let count = 0;
        
        // 判断c是否为字母
        if (/[a-zA-Z]/.test(c)) {
            // 字母:统计大小写形态
            const lowerC = c.toLowerCase();
            const upperC = c.toUpperCase();
            
            for (let i = 0; i < s.length; i++) {
                const char = s[i];
                if (char === lowerC || char === upperC) {
                    count++;
                }
            }
        } else {
            // 数字:精确匹配
            for (let i = 0; i < s.length; i++) {
                if (s[i] === c) {
                    count++;
                }
            }
        }
        
        console.log(count);
        rl.close();
    }
});
相关推荐
小则又沐风a3 分钟前
进一步了解进程---第四章 进程管理
java·服务器·前端
放下华子我只抽RuiKe54 分钟前
FastAPI 全栈后端(一):为什么选择 FastAPI
前端·javascript·深度学习·react.js·机器学习·前端框架·fastapi
ZC跨境爬虫5 分钟前
跟着 MDN 学CSS day_11:(深入理解CSS值与单位的完整体系)
前端·css·ui·html·tensorflow
青云计划8 分钟前
SSE流式响应:从Reactor Flux到生产级AI聊天的工程实践——5分钟超时、线程隔离、背压处理全解析
前端·人工智能·firefox
A南方故人14 分钟前
将容器内的元素变为可拖拽
开发语言·javascript·ecmascript
codefan※24 分钟前
7 个Prompt 框架汇总:从 Chain of Thought 到 ReAct + PoT
前端·react.js·ai·llm·prompt·prompt工程·思维链
迁旭26 分钟前
Claude Code /status 功能技术文档
前端·javascript·人工智能·react.js·机器学习·gpt-3·文心一言
星星~笑笑30 分钟前
react Next.js oss上传 上传阿里云
javascript·react.js·阿里云·js
GISer_Jing31 分钟前
前端全流程求职Skill 攻略
前端·学习·前端框架