uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401

2024-09-09 16:48

本文主要是介绍uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题意是求在base进制下的 n!的结果有几位数,末尾有几个0。

想起刚开始的时候做的一道10进制下的n阶乘末尾有几个零,以及之前有做过的一道n阶乘的位数。

当时都是在10进制下的。


10进制下的做法是:

1. n阶位数:直接 lg(n!)就是得数的位数。

2. n阶末尾0的个数:由于2 * 5 将会在得数中以0的形式存在,所以计算2或者计算5,由于因子中出现5必然出现2,所以直接一趟遍历,找出能整除5的数就行了,5的个数就是末尾0的个数。


推广到base进制下:

1. n阶的位数:log base (n!),换底公式,可以换成 lg(n!) /  lg(base)。

2.n阶末尾0的个数:在n!中找可以凑成base的因子,比如16,可以找1, 16或者2,8或者4,4。

具体做法是n!里面的每一个数都分解成因子相乘的形式,并记录下来,然后到base中去凑,若能凑成,阶乘末尾就多一个0。


代码:

#include <stdio.h>
#include <math.h>
#include <string.h>int n, base;
int a[1000];//记录n中小于等于base的因子数int ZeroNum()
{memset(a, 0, sizeof(a));//将n!中的所有数拆分出因子,并记录下来该因子(j)对应有多少个for (int i = 2; i <= n; i++){int tmp = i;for (int j = 2; j <= tmp && j <= base; j++){while (tmp % j == 0){a[j]++;tmp /= j;}}}//将拆分出的因子枚举,若其能拼凑成一组base,则出现一个0。int res = 0;while (1){int tmp =  base;for (int i = 2; i <= tmp; i++){while (tmp % i == 0 && a[i] > 0){a[i]--;tmp /= i;}}if (tmp == 1)res++;elsebreak;}return res;
}int DigitNum()
{double sum = 0;int res;for (int i = 1; i <= n; i++){sum += log(i);}res = sum / log(base) + 1;return res;
}int main()
{#ifdef LOCALfreopen("in.txt", "r", stdin);#endif // LOCALwhile (scanf("%d%d", &n, &base) == 2){printf("%d %d\n", ZeroNum(), DigitNum());}return 0;
}

大神带你飞。

不理解这个求末尾0的做法:

add 2014.12.30:

正在学习数论,看完书再翻回来看这个代码就懂了。

这是素数的一个基本定理,即:n!的素因子分解种的素数p的幂为:(n / p) + (n / p ^ 2) + (n / p ^ 3) + …

在十进制下,能凑成末尾0的因子是2,5,而对于n!,在因式分解中,2的因子个数要大于5的因子个数(++先到2后到5,so有5必有2)。

所以如果存在一个因子5,必然对应着n!末尾的一个0,所以就变成了求n!中5的因子数,直接由性质得出,见下题poj1401.


转换成base进制下,自然成了找到乘积为base中最大的那个素因子,然后算有几个,最后转换下进制就行了。


#include <stdio.h>
#include <math.h>int main()
{#ifdef LOCALfreopen("in.txt", "r", stdin);#endif // LOCALint n, base;while (scanf("%d%d", &n, &base) == 2){int num;double sum = 0;//计算位数for (int i = 1; i <= n; i++){sum += log(i);}num = sum / log(base) + 1;//计算末位0的个数int cnt2 = 0;int cnt1;int maxprime;
//找最大素因子
for (int i = 2; i <= base; i++){cnt1 = 0;while (base % i == 0){maxprime = i;cnt1++;base /= i;}}while (n){n /= maxprime;cnt2 += n;}printf("%d %d\n", cnt2 / cnt1, num);}return 0;
}

poj 1401:

#include <stdio.h>
#include <math.h>int findZero(int n, int base)
{int cnt2 = 0;int cnt1;int maxprime;for (int i = 2; i <= base; i++){cnt1 = 0;while (base % i == 0){maxprime = i;cnt1++;base /= i;}}while (n){n /= maxprime;cnt2 += n;}return cnt2 / cnt1;
}int main()
{
#ifdef LOCAL//freopen("in.txt", "r", stdin);
#endif // LOCALint ncase;scanf("%d", &ncase);while (ncase--){int n;scanf("%d", &n);printf("%d\n", findZero(n, 10));}return 0;
}


这篇关于uva 10061 How many zero's and how many digits ?(不同进制阶乘末尾几个0)+poj 1401的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151728

相关文章

Java使用SLF4J记录不同级别日志的示例详解

《Java使用SLF4J记录不同级别日志的示例详解》SLF4J是一个简单的日志门面,它允许在运行时选择不同的日志实现,这篇文章主要为大家详细介绍了如何使用SLF4J记录不同级别日志,感兴趣的可以了解下... 目录一、SLF4J简介二、添加依赖三、配置Logback四、记录不同级别的日志五、总结一、SLF4J

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

mysql出现ERROR 2003 (HY000): Can‘t connect to MySQL server on ‘localhost‘ (10061)的解决方法

《mysql出现ERROR2003(HY000):Can‘tconnecttoMySQLserveron‘localhost‘(10061)的解决方法》本文主要介绍了mysql出现... 目录前言:第一步:第二步:第三步:总结:前言:当你想通过命令窗口想打开mysql时候发现提http://www.cpp

MySQL中慢SQL优化的不同方式介绍

《MySQL中慢SQL优化的不同方式介绍》慢SQL的优化,主要从两个方面考虑,SQL语句本身的优化,以及数据库设计的优化,下面小编就来给大家介绍一下有哪些方式可以优化慢SQL吧... 目录避免不必要的列分页优化索引优化JOIN 的优化排序优化UNION 优化慢 SQL 的优化,主要从两个方面考虑,SQL 语

Python如何计算两个不同类型列表的相似度

《Python如何计算两个不同类型列表的相似度》在编程中,经常需要比较两个列表的相似度,尤其是当这两个列表包含不同类型的元素时,下面小编就来讲讲如何使用Python计算两个不同类型列表的相似度吧... 目录摘要引言数字类型相似度欧几里得距离曼哈顿距离字符串类型相似度Levenshtein距离Jaccard相

在不同系统间迁移Python程序的方法与教程

《在不同系统间迁移Python程序的方法与教程》本文介绍了几种将Windows上编写的Python程序迁移到Linux服务器上的方法,包括使用虚拟环境和依赖冻结、容器化技术(如Docker)、使用An... 目录使用虚拟环境和依赖冻结1. 创建虚拟环境2. 冻结依赖使用容器化技术(如 docker)1. 创

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明

java中不同版本JSONObject区别小结

《java中不同版本JSONObject区别小结》本文主要介绍了java中不同版本JSONObject区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1. FastjsON2. Jackson3. Gson4. org.json6. 总结在Jav

Python中连接不同数据库的方法总结

《Python中连接不同数据库的方法总结》在数据驱动的现代应用开发中,Python凭借其丰富的库和强大的生态系统,成为连接各种数据库的理想编程语言,下面我们就来看看如何使用Python实现连接常用的几... 目录一、连接mysql数据库二、连接PostgreSQL数据库三、连接SQLite数据库四、连接Mo

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.