RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1193474
Accepted
A_Hatake
A_Hatake
Asked:2021-10-21 23:54:55 +0000 UTC2021-10-21 23:54:55 +0000 UTC 2021-10-21 23:54:55 +0000 UTC

大数的阶乘

  • 772

您需要计算数字 N 的阶乘,其中 1<=N<=1000。您还需要在响应中提供最多 3000 个字符。我写了一个程序,它在编译器中运行良好:

#include <stdio.h>
#include <gmp.h>

static void
factorial (long n, mpz_t r)
{ 
  mpz_init_set_si (r, 1);
  for (; n > 1; n--) {
    mpz_mul_si (r, r, n);
  }
}

int
main (void)
{
  int n;
  mpz_t r;
  while (scanf ("%d", &n) == 1) {
    factorial (n, r);
    gmp_printf ("%Zd\n", r);
  }
  return 0;
}

但是测试系统不接受代码,因为 不知道 GMP 库。告诉我如何解决这个问题?

c
  • 3 3 个回答
  • 10 Views

3 个回答

  • Voted
  1. Yuri Kovalenko
    2021-10-22T00:35:38Z2021-10-22T00:35:38Z

    最有可能的是,测试系统要求您知道算术的工作时间,以及用代码编写它的能力(即对编程语言有足够的了解)。系统的目的不太可能是检查代码的简洁性或简单性。

    但是,如果您真的不想手动实现长算法,那么我看到了另一种方法:获取库代码并将其复制粘贴到您的文件中。这可能会导致问题:

    • 系统很可能对解决方案的大小有限制,您可以通过这种方式超过它;
    • 如果你的决定也会被人检查(例如,如果你以学生的身份完成任务,有时老师会这样做),那么你的伎俩就会被揭露;

    事实上,如果你的任务是专门用 C 编写代码,这种技巧几乎等同于作弊。如果 Java 或 Python 也可以从选项中获得(它们在标准库级别支持长数字),那么这更像是一个机会的平衡:)

    PS:这是可以内置到您的解决方案中的库的变体:. 测试甚至有一个使用它的阶乘计算示例。

    • 3
  2. Best Answer
    A_Hatake
    2021-10-22T01:33:02Z2021-10-22T01:33:02Z

    简而言之,这是系统最终接受的代码:

    #include<stdio.h>
     
    #define MAX 3000
    
    int multiply(int x, int res[], int res_size);
     
    void factorial(int n)
    {
        int res[MAX];
         
        res[0] = 1;
        int res_size = 1;
         
        for (int x=2; x<=n; x++)
            res_size = multiply(x, res, res_size);
     
        for (int i=res_size-1; i>=0; i--)
            printf ("%d",res[i]);
    }
     
    int multiply(int x, int res[], int res_size)
    {
        int carry = 0;  // Инициализируем перенос
         
        for (int i=0; i<res_size; i++)
        {
            int prod = res[i] * x + carry;
             
            res[i] = prod % 10;  
             
            carry  = prod/10;    
        }
        
        while (carry)
        {
            res[res_size] = carry%10;
            carry = carry/10;
            res_size++;
        }
        return res_size;
    }
     
    int main()
    {   int n;
        scanf ("%d", &n);
        factorial(n);
        return 0;
    }
    
    • 3
  3. A_Hatake
    2021-10-22T00:49:34Z2021-10-22T00:49:34Z

    这是另一种解决方案,但测试系统再次不想接受它......

    int main(int argc, char** argv)
    {
        int i,j,d,sz,n=30;
        char *f=calloc(2,sizeof(char));
        *f='1';
        for(d=0,i=1; i<=n; i++)
        {
            sz=strlen(f);
            for(j=sz-1; j>=0; j--,d/=10)
            {
                d+=(f[j]-'0')*i;
                f[j]=d%10+'0';
            }
            for(sz++; d; d/=10,sz++)
            {
                f=realloc(f,(sz+1)*sizeof(char));
                memmove(f+1,f,sz*sizeof(char));
                *f=d%10+'0';
            }
            //printf("%s\n",f);
        }
        printf("%d!=%s\n",n,f);
        free(f);
        system("pause");
        return 0;
    }
    
    • 0

相关问题

  • free 出于某种原因不会从内存中删除数组

  • 请帮助代码

  • 为什么 masm 对字符串或文本文字太长发誓,为什么在结构中设置 db 或 dw?

  • 如何将数字拆分为位并将其写入 C 中的数组?

  • 如何以给定的角度移动物体?

  • 解决“子集和问题”的时效算法

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    如何从列表中打印最大元素(str 类型)的长度?

    • 2 个回答
  • Marko Smith

    如何在 PyQT5 中清除 QFrame 的内容

    • 1 个回答
  • Marko Smith

    如何将具有特定字符的字符串拆分为两个不同的列表?

    • 2 个回答
  • Marko Smith

    导航栏活动元素

    • 1 个回答
  • Marko Smith

    是否可以将文本放入数组中?[关闭]

    • 1 个回答
  • Marko Smith

    如何一次用多个分隔符拆分字符串?

    • 1 个回答
  • Marko Smith

    如何通过 ClassPath 创建 InputStream?

    • 2 个回答
  • Marko Smith

    在一个查询中连接多个表

    • 1 个回答
  • Marko Smith

    对列表列表中的所有值求和

    • 3 个回答
  • Marko Smith

    如何对齐 string.Format 中的列?

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5