前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【牛客网】BC146 添加逗号

【牛客网】BC146 添加逗号

作者头像
修修修也
发布2024-04-01 15:10:24
1110
发布2024-04-01 15:10:24
举报
文章被收录于专栏:修也的进阶日记

一.题目描述

描述:

对于一个较大的整数 N(1<=N<=2,000,000,000) 比如 980364535,我们常常需要一位一位数这个数字是几位数,但是如果在这 个数字每三位加一个逗号,它会变得更加易于朗读。 因此,这个数字加上逗号成如下的模样:980,364,535请写一个程序帮她完成这件事情.

输入描述:

一行一个整数 N.

输出描述:

一行一个字符串表示添加完逗号的结果.

示例1:

输入:980364535 输出:980,364,535

备注:

1<=n<=2,000,000,000

题目详情:

二.题目思路

首先,我们可以将整形N通过每次%10的方式将其末位数字存放在字符数组arr中.

其次,可以每存三个数字,就往数组里存放一个' , '.

最后,将数组逆序打印即可得到我们想要的效果.

思路图解如下:

要注意的是,在编写好程序后我们可能会遇到如下问题:

加入'计数器k'后代码及详细解析如下:

代码语言:javascript
复制
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
int main()
{
    int N = 0;//创建整形变量n,用来接收题目输入数据
    scanf("%d", &N);//用scanf接收数据
    char arr[14] = { 0 };//创建字符数组,存储从整形上剥下来的数据
    int i = 0;//用来记录数组录入的次序
    int k = 0;//用来随第15行的i++同步调整,以便第13行的if语句可以正常判断
    while (N)
    {
        if (i != 0 && i % 3 == k)//i!=0防止录入最后一个数字时给其后面加','
        {
            arr[i++] = ',';
            k++;
        }
        arr[i++] = N % 10 + '0';//将N的末尾剥下来放入数组arr中
        N /= 10;//剥完后舍去末位数字
    }
    i--;//上述循环中i最后会多加一次,不减去的话,后续打印会造成数组越界访问
    for (; i >= 0; i--)//倒序进行循环,即从i->0
    {
        printf("%c", arr[i]);//打印数组下标为i的字符
    }
    return 0;
}

三.完整解题代码

根据上述思路,本题解题代码如下:

代码语言:javascript
复制
#define _CRT_SECURE_NO_WARNINGS 1

#include <stdio.h>
int main()
{
    int n=0;
    scanf("%d",&n);
    char arr[14]={0};
    int i=0;
    int k=0;
    while(n)
    {
        if(i!=0&&i%3==k)
        {
            arr[i++]=',';
            k++;
        }
        arr[i++]=n%10+'0';
        n/=10;
    }
    i--;
    for(;i>=0;i--)
    {
        printf("%c",arr[i]);
    }
    return 0;
}

拷贝到牛客网测试运行:

成功通过:

今日感悟:不做不必要的担忧,不做遥远的规划,从来没有所谓既定轨道能如约丝毫不差的驶向终点.

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-04-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一.题目描述
  • 描述:
  • 输入描述:
  • 输出描述:
  • 示例1:
  • 备注:
  • 题目详情:
  • 二.题目思路
  • 三.完整解题代码
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档