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;
}
相关推荐
糖葫芦君36 分钟前
Policy Gradient【强化学习的数学原理】
算法
向阳@向远方2 小时前
第二章 简单程序设计
开发语言·c++·算法
github_czy3 小时前
RRF (Reciprocal Rank Fusion) 排序算法详解
算法·排序算法
许愿与你永世安宁4 小时前
力扣343 整数拆分
数据结构·算法·leetcode
爱coding的橙子4 小时前
每日算法刷题Day42 7.5:leetcode前缀和3道题,用时2h
算法·leetcode·职场和发展
满分观察网友z4 小时前
从一次手滑,我洞悉了用户输入的所有可能性(3330. 找到初始输入字符串 I)
算法
YuTaoShao5 小时前
【LeetCode 热题 100】73. 矩阵置零——(解法二)空间复杂度 O(1)
java·算法·leetcode·矩阵
Heartoxx5 小时前
c语言-指针(数组)练习2
c语言·数据结构·算法
大熊背5 小时前
图像处理专业书籍以及网络资源总结
人工智能·算法·microsoft
满分观察网友z5 小时前
别怕树!一层一层剥开它的心:用BFS/DFS优雅计算层平均值(637. 二叉树的层平均值)
算法