ACM 纳新每日一题 4329: 三进制

首先我们要学习的是数制转化

这里我找了一篇博客
https://blog.csdn.net/weixin_53564801/article/details/123665194

一定要注意0需要单独特判一下,这个点尤其重要

然后关于这道题可以使用递归来实现,如下:

递归的代码比较简洁,但是理解起来难度较大

cpp 复制代码
#include<stdio.h>

void fun(int n)
{
    if(n==0)
    {
        return;
    }
    fun(n/3);
    printf("%d",n%3);
}

int main()
{
    int n;
    scanf("%d",&n);

    if(n==0)
    {
        printf("0\n");
    }
    else
    {
        fun(n);
    }

    return 0;
}

也可以使用字符数组来存储然后逆序输出就可以,这样符合进制转化的思路,直接将模的结果存储起来然后逆序输出就好

cpp 复制代码
#include<stdio.h>

int main()
{
    int n;
    scanf("%d",&n);

    char s[30];

    int cnt=0;

    if(n==0)
    {
        printf("0\n");
    }
    else
    {
        while(n)
        {
            s[cnt++]=n%3;
            n/=3;
        }

        for(int i=cnt-1; i>=0; i--)
        {
            printf("%d",s[i]);
        }
    }


    return 0;
}
相关推荐
kisshyshy13 小时前
从递归到迭代,一文吃透二叉树的核心知识与 JavaScript 实现
javascript·算法·代码规范
To_OC1 天前
LC 49 字母异位词分组:想到哈希表很简单,选对 key 才是精髓
javascript·算法·leetcode
用户938515635071 天前
从 O(n²) 到 O(nlogn):一文读懂快速排序的“快”与“妙”
javascript·算法
To_OC1 天前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 天前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者1 天前
Transformer模型部署之性能优化指南
算法
地平线开发者1 天前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月1 天前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星2 天前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星2 天前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试