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

    你可能感兴趣的文章
    NPOI之Excel——合并单元格、设置样式、输入公式
    查看>>
    NPOI利用多任务模式分批写入多个Excel
    查看>>
    NPOI格式设置
    查看>>
    Npp删除选中行的Macro录制方式
    查看>>
    NR,NF,FNR
    查看>>
    nrf开发笔记一开发软件
    查看>>
    NS3 IP首部校验和
    查看>>
    NSDateFormatter的替代方法
    查看>>
    NSError 的使用方法
    查看>>
    nsis 安装脚本示例(转)
    查看>>
    NSOperation基本操作
    查看>>
    NSRange 范围
    查看>>
    NSSet集合 无序的 不能重复的
    查看>>
    NT AUTHORITY\NETWORK SERVICE 权限问题
    查看>>
    NT symbols are incorrect, please fix symbols
    查看>>
    ntko web firefox跨浏览器插件_深度比较:2019年6个最好的跨浏览器测试工具
    查看>>
    ntko文件存取错误_苹果推送 macOS 10.15.4:iCloud 云盘文件夹共享终于来了
    查看>>
    ntpdate 通过外网同步时间
    查看>>
    NTP配置
    查看>>
    NUC1077 Humble Numbers【数学计算+打表】
    查看>>