ZCMU-1129一不小心爱上你(公式水题)

这篇博客讨论了一个关于阶乘位数的数学问题,给出了解决方法和相关算法。作者通过一道具体的题目——计算520的阶乘位数,引入了一个公式来快速求解类似问题。代码示例展示了如何利用此公式实现快速计算,并给出了样例输入和输出。

题目

1129: 第五章:一不小心爱上你

Time Limit: 5 Sec Memory Limit: 128 MB
Submit: 661 Solved: 176
[Submit][Status][Web Board]
Description

O型血的人大多数是行动派,郑微更是将这个特征发挥到了极致。次日上课,阮阮前所未有地发现她在课堂上奋笔疾书,大为惊讶,便凑过去问了一声,“在写什么呀?”郑微大大方方地向阮阮展示了她一早上的智慧结晶,阮阮看了看,“俘虏陈孝正详细行动攻略……”她念完,顿时无语。挺漂亮的一本崭新小本本,上面已经洋洋洒洒地写了将近十页,蝇头小字,字字工整,各个环节、各个步骤无一不详,关键地方和注意事项甚至还用下划线标了出来。

行动攻略第一条:在自习教室偶遇陈孝正,郑薇坐在了他的后面,假装不知道,问了他一个数学问题:你知道520的阶乘有多少位么?但是,陈孝正却根本没有理睬郑薇。。

这个问题的答案,你知道么?赶紧想好了,如果哪天有人来问你。。。。。。

Input

每行一个N,0<=N<10^7,你要快速回答哦!

Output

输出N的阶乘的位数。

Sample Input

5
6
520

Sample Output

3
3
1189

想法

这道题初看可能觉得暴力肯定炸,网上一搜原来有公式······
在这里插入图片描述

在这里插入图片描述

那就直接套公式完事了····

int str(int n)
{
     return floor(log10(sqrt(2*PI*n))+n*log10(n/e))+1;
}

AC代码

#include<bits/stdc++.h>
using namespace std;
#define rep(i,a,b) for(int i=a;i<=b;++i)
#define pre(i,a,b) for(int i=a;i>=b;--i)
#define m(x) memset(x,0,sizeof x)
const double PI = acos(-1);
const double e = exp(double(1));
const int maxn = 1e6+5;
int str(int n)
{
    return floor(log10(sqrt(2*PI*n))+n*log10(n/e))+1;
}
int main()
{
    
    int n;
    while(~scanf("%d",&n))
    {
        if(n<=3)printf("1\n");
        else
        printf("%d\n",str(n));
    }
    return 0;
}


### zcmu 1817 相关 IT 内容或问 zcmu 1817 是一个与算法竞赛相关的目,通常出现在 Zhejiang Commerce University (浙商大) 的在线评测系统中。这类目通常涉及基础的算法知识和编程技巧。以下是对该目的详细分析以及相关背景信息。 #### 目描述 zcmu 1817 的具体目描述可能未直接提供,但根据常见的在线评测系统的惯例,这类目通常会涉及以下几个方面: - **输入输出**:需要处理一组或多组输入数据,并按照特定规则生成输出。 - **算法类型**:可能是数学计算、字符串处理、排序、搜索等常见算法- **时间与空间限制**:通常会有明确的时间限制(如 1 秒)和内存限制(如 128 MB)[^4]。 假设 zcmu 1817 是一个典型的算法竞赛目,下面是一个可能的场景: #### 示例场景 假设 zcmu 1817 的目要求如下: - 给定一个整数数组 `arr`,找到其中的最大值和最小值,并输出它们的差值。 - 输入格式:第一行包含一个整数 `n`,表示数组的长度;第二行包含 `n` 个整数,表示数组的元素。 - 输出格式:输出一个整数,表示最大值与最小值的差值。 #### 示例代码实现 以下是解决上述问的一个 Python 实现: ```python # 输入处理 n = int(input()) arr = list(map(int, input().split())) # 找到最大值和最小值 max_value = max(arr) min_value = min(arr) # 计算差值并输出 result = max_value - min_value print(result) ``` #### 注意事项 在解决此类问时,需要注意以下几点: - **边界条件**:例如数组只有一个元素的情况,此时最大值与最小值相同,差值为 0[^5]。 - **输入验证**:确保输入数据符合目要求,避免因非法输入导致程序崩溃。 - **效率优化**:对于大规模数据,需确保算法的时间复杂度和空间复杂度满足目限制。 #### 算法复杂度分析 上述代码的时间复杂度为 \(O(n)\),其中 \(n\) 是数组的长度。这是因为 `max()` 和 `min()` 函数分别需要遍历整个数组一次。空间复杂度为 \(O(1)\),因为只使用了常量级别的额外空间[^6]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值