鱼C论坛

 找回密码
 立即注册
查看: 1596|回复: 2

[已解决]关于阶乘的问题

[复制链接]
发表于 2017-12-11 22:05:33 | 显示全部楼层 |阅读模式
15鱼币
这是题目,下面是我的代码,思路就是找到先找到比输入的数小的最大的阶乘,然后减去后继续重复该步骤,直至最后恰好为0输出“YES”或最后不可能减为0输出“NO”,但那个批改系统说我的代码结果有误,求大神解!
#include <stdio.h>
#include <stdlib.h>

int jiecheng(int i)
{
    if (i==1) return 1;
    return i*jiecheng(i-1);
}

int main()
{
    int n,n1;
    int i1=8;
    int m;
    scanf("%d",&n);
    n1=n;
    while (1)
    {
        for(int i=i1;i1>0;i--)
        {
            if (jiecheng(i)<=n1&&jiecheng(i+1)>n1)
            {
                m=jiecheng(i);
                i1 = i-1;
                break;
            }
            m=jiecheng(i);
            i1 = i-1;
        }
        if(i1==0&&n1-m!=0)
        {
            printf("NO");
            break;
        }
        else if(n1-m==0||n1-m==1)
        {
            printf("YES");
            break;
        }
        else if(n1-m<0)
        {
            printf("NO");
            break;
        }
        n1-=m;
    }

    return 0;
}
最佳答案
2017-12-11 22:05:34
你设置i1=8是怎么想的?
NOJ087.jpg

最佳答案

查看完整内容

你设置i1=8是怎么想的?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-12-11 22:05:34 | 显示全部楼层    本楼为最佳答案   
你设置i1=8是怎么想的?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2017-12-12 13:21:25 From FishC Mobile | 显示全部楼层
BngThea 发表于 2017-12-12 09:40
你设置i1=8是怎么想的?

哦,应该是9,8的阶乘才3万多,我换过后就对了,谢谢
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-19 11:24

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表