博客
关于我
牛客网 PAT 算法历年真题 1011 : 个位数统计 (15)
阅读量:431 次
发布时间:2019-03-06

本文共 1061 字,大约阅读时间需要 3 分钟。

问题描述

给定一个k位整数N = d_{k-1}×10^{k-1} + ... + d_1×10 + d_0 (其中0 ≤ d_i ≤9,i=0,...,k-1,d_{k-1} >0),请编写程序统计每种不同的个位数字出现的次数。例如:给定N = 100311,则有2个0,3个1,和1个3。

输入描述

每个输入包含1个测试用例,即一个不超过1000位的正整数N。

输出描述

对N中每一种不同的个位数字,以D:M的格式在一行中输出该位数字D及其在N中出现的次数M。要求按D的升序输出。

输入例子

100311

输出例子

0:2 1:3 3:1


思路分析

将输入的字符串转换为字符数组,逐个字符统计每个数字出现的次数。由于只关注个位数字(0-9),可以直接遍历每个字符,更新对应的计数器。最后按顺序输出结果。

解决代码

import java.util.Scanner;public class Main {    public static void main(String[] args) {        Scanner sca = new Scanner(System.in);        String str = sca.next();        int[] sum = new int[10]; // 数组索引代表数字,值代表出现次数        for (int i = 0; i < str.length(); i++) {            char c = str.charAt(i);            sum[c - '0']++; // 将字符转换为数字,更新对应的计数器        }        for (int i = 0; i < sum.length; i++) {            if (sum[i] > 0) {                System.out.println(i + ":" + sum[i]);            }        }    }}

代码解释

  • 输入读取:使用Scanner读取输入的整数字符串。
  • 计数器初始化:创建一个大小为10的数组sum,每个元素对应数字0-9的出现次数。
  • 字符遍历:逐个遍历字符串中的每个字符,将其转换为数字,并更新对应的计数器。
  • 结果输出:遍历计数器数组,输出每个非零计数的结果,按升序排列。
  • 这种方法的时间复杂度为O(n),其中n为输入字符串的长度,能够高效处理长达1000位的整数。

    转载地址:http://kbcyz.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty常见组件二
    查看>>
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>