博客
关于我
牛客网 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/

    你可能感兴趣的文章
    MapReduce程序依赖的jar包
    查看>>
    mariadb multi-source replication(mariadb多主复制)
    查看>>
    MaterialForm对tab页进行隐藏
    查看>>
    Member var and Static var.
    查看>>
    memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
    查看>>
    memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
    查看>>
    Memcached:Node.js 高性能缓存解决方案
    查看>>
    memcache、redis原理对比
    查看>>
    memset初始化高维数组为-1/0
    查看>>
    Metasploit CGI网关接口渗透测试实战
    查看>>
    Metasploit Web服务器渗透测试实战
    查看>>
    Moment.js常见用法总结
    查看>>
    MongoDB出现Error parsing command line: unrecognised option ‘--fork‘ 的解决方法
    查看>>
    mxGraph改变图形大小重置overlay位置
    查看>>
    MongoDB学习笔记(8)--索引及优化索引
    查看>>
    MQTT工作笔记0009---订阅主题和订阅确认
    查看>>
    ms sql server 2008 sp2更新异常
    查看>>
    MS UC 2013-0-Prepare Tool
    查看>>
    msbuild发布web应用程序
    查看>>
    MSB与LSB
    查看>>