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;
}
相关推荐
vir0236 分钟前
密码脱落(最长回文子序列)
数据结构·c++·算法
福尔摩斯张1 小时前
二维数组详解:定义、初始化与实战
linux·开发语言·数据结构·c++·算法·排序算法
冰西瓜6001 小时前
模与内积(五)矩阵分析与应用 国科大
线性代数·算法·矩阵
努力学算法的蒟蒻1 小时前
day17(11.18)——leetcode面试经典150
算法·leetcode·面试
缘友一世1 小时前
模型微调DPO算法原理深入学习和理解
算法·模型微调·dpo
未若君雅裁1 小时前
斐波那契数列 - 动态规划实现 详解笔记
java·数据结构·笔记·算法·动态规划·代理模式
断剑zou天涯1 小时前
【算法笔记】从暴力递归到动态规划(三)
java·算法·动态规划
RQ_ghylls1 小时前
2.excel每3行计算一个均值,将高于均值的单元格设置背景红色
算法·均值算法·word·excel
断剑zou天涯1 小时前
【算法笔记】从暴力递归到动态规划(一)
java·算法·动态规划
不爱编程爱睡觉2 小时前
代码随想录算法训练营第二十八天 | 动态规划算法基础、 LeetCode509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法·leetcode·动态规划·代码随想录