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

    你可能感兴趣的文章
    Nvidia Cudatoolkit 与 Conda Cudatoolkit
    查看>>
    NVIDIA GPU 的状态信息输出,由 `nvidia-smi` 命令生成
    查看>>
    NVIDIA-cuda-cudnn下载地址
    查看>>
    nvidia-htop 使用教程
    查看>>
    nvidia-smi 参数详解
    查看>>
    nvm安装以后,node -v npm 等命令提示不是内部或外部命令 node多版本控制管理 node多版本随意切换
    查看>>
    NYOJ 1066 CO-PRIME(数论)
    查看>>
    nyoj------203三国志
    查看>>
    nyoj58 最少步数
    查看>>
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>