题目2674:蓝桥杯2022年第十三届省赛真题-求阶乘

简介: 题目2674:蓝桥杯2022年第十三届省赛真题-求阶乘

时间限制: 1s 内存限制: 512MB 提交: 1407 解决: 513


题目描述

满足 N! 的末尾恰好有 K 个 0 的最小的 N 是多少?

如果这样的 N 不存在输出 −1。

输入格式

一个整数 K。

输出格式

一个整数代表答案。



样例输入

复制

2

样例输出

复制

10



提示

对于 30% 的数据,1 ≤ K ≤ 106 .

对于 100% 的数据,1 ≤ K ≤ 1018 .

#include <iostream>
using namespace std;
int find2(int n) {
  int i = 0;
  while (n % 2 == 0 && n != 0) {
    i++;
    n /= 2;
  }
  return i;
}
int find5(int n) {
  int i = 0;
  while (n % 5 == 0 && n != 0) {
    i++;
    n /= 5;
  }
  return i; 
}
int main() {
  int K;
  int i = 0;
  int j = 0;
  int I = 2;
  int J = 5;
  cin >> K;
  while (min(i,j) <= K) {
      i += find2(I);
      I += 2;
    j += find5(J);
    if (min(i, j) == K) {
      cout << J;
      return 0;
    }
    J += 5;
  }
  cout << -1;
  return 0;
}

代码没过全部用例,随便看看吧

















相关文章
|
4月前
|
Java
2023蓝桥杯大赛省赛Java大学B组 阶乘求和
2023蓝桥杯大赛省赛Java大学B组 阶乘求和
18 0
|
4月前
|
Java
2022蓝桥杯大赛软件类省赛Java大学B组E题 求阶乘-CSDN博客
2022蓝桥杯大赛软件类省赛Java大学B组E题 求阶乘-CSDN博客
25 0
|
4月前
|
人工智能 算法 搜索推荐
蓝桥杯宝藏排序题目算法(冒泡、选择、插入)
以下是内容的摘要: 本文介绍了三种排序算法:冒泡排序、选择排序和插入排序。冒泡排序通过不断交换相邻的逆序元素逐步排序,最坏情况下需要 O(n^2) 次比较。选择排序在每轮中找到剩余部分的最小元素并放到已排序序列的末尾,同样具有 O(n^2) 时间复杂度。插入排序则是将每个元素插入到已排序序列的正确位置,时间复杂度也是 O(n^2),但空间复杂度为 O(1)。
|
5月前
|
存储 人工智能 算法
第十四届蓝桥杯C++B组编程题题目以及题解
第十四届蓝桥杯C++B组编程题题目以及题解
|
5月前
|
测试技术
题目1444:蓝桥杯2014年第五届真题斐波那契
题目1444:蓝桥杯2014年第五届真题斐波那契
53 0
|
人工智能 移动开发 机器人
蓝桥杯AcWing 题目题解 - 二分与前缀和、差分
蓝桥杯AcWing 题目题解 - 二分与前缀和、差分
146 0
蓝桥杯AcWing 题目题解 - 递归与递推
蓝桥杯AcWing 题目题解 - 递归与递推
|
存储 机器学习/深度学习 算法
【java_蓝桥杯算法训练 】试题 算法训练 阶乘
一个整数n的阶乘可以写成n!,它表示从1到n这n个整数的乘积。阶乘的增长速度非常快,例如,13!就已经比较大了,已经无法存放在一个整型变量中;而35!就更大了,它已经无法存放在一个浮点型变量中。因此,当n比较大时,去计算n!是非常困难的。幸运的是,在本题中,我们的任务不是去计算n!,而是去计算n!最右边的那个非0的数字是多少。例如,5! = 1*2*3*4*5 = 120,因此5!最右边的那个非0的数字是2。再如:7! = 5040,因此7!最右边的那个非0的数字是4。请编写一个程序,输入一个整数n(n<=100),然后输出n! 最右边的那个非0的数字是多少。   输入格式:输入只有一个整数n
94 0
|
算法 测试技术
蓝桥杯2022年第十三届决赛真题-卡牌——二分法
蓝桥杯2022年第十三届决赛真题-卡牌——二分法
121 0
|
算法 前端开发
蓝桥杯 —— Web前端(算法类)【标题即题目链接,点击查看具体要求】
蓝桥杯 —— Web前端(算法类)【标题即题目链接,点击查看具体要求】
195 0