C++程序用于计算使数字n变为1所需的最小操作次数

c++程序用于计算使数字n变为1所需的最小操作次数

假设我们有一个数字n。我们任意执行这些操作之一 –

当 n 可被 2 整除时,将 n 替换为 n/2

当 n 可被 3 整除时,将 n 替换为 2n/3

当 n 可被 5 整除时,将 n 替换为 4n/5

立即学习“C++免费学习笔记(深入)”;

li>

我们必须计算出数字 1 所需的最小移动次数。如果不可能,则返回 -1。

因此,如果输入类似于 n = 10,则输出将为 4,因为使用 n/2 得到 5,然后使用 4n/5 得到 4,然后再次 n/2 得到 2,再次 n/2 得到 1。

步骤

步骤 h2>

为了解决这个问题,我们将按照以下步骤操作 –

m := 0while n is not equal to 1, do:   if n mod 2 is same as 0, then:      n := n / 2      (increase m by 1)   otherwise when n mod 3 is same as 0, then:      n := n / 3      m := m + 2   otherwise when n mod 5 is same as 0, then:      n := n / 5      m := m + 3   Otherwise      m := -1      Come out from the loopreturn m

示例

让我们看看以下实现,以便更好地理解 –

#include using namespace std;int solve(int n) {   int m = 0;   while (n != 1) {      if (n % 2 == 0) {         n = n / 2;         m++;      }      else if (n % 3 == 0) {         n = n / 3;         m += 2;      }      else if (n % 5 == 0) {         n = n / 5;         m += 3;      }      else {         m = -1;         break;      }   }   return m;}int main() {   int n = 10;   cout << solve(n) << endl;}

输入

10

输出

4

以上就是C++程序用于计算使数字n变为1所需的最小操作次数的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445202.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:17:29
下一篇 2025年12月17日 22:17:49

相关推荐

  • 使用堆栈在C++中反转一个数字

    We are given an integer number Num as input. The goal is to find the reverse of the number using stack. Stack:- A stack is a data structure in C++ whi…

    2025年12月17日
    000
  • 找出在范围内不可被任何数整除的数字,使用C++

    在本文中,我们将讨论查找 1 到 n(给定)之间的数字的问题,这些数字不能被 2 到 10 之间的任何数字整除。让我们通过一些例子来理解这一点 – Input : num = 14Output : 3Explanation: There are three numbers, 1, 11,…

    2025年12月17日
    000
  • C++程序将一个数字四舍五入到n位小数

    在任何语言中编写程序时,将数字表示为输出是一项有趣且重要的任务。对于整数类型(short、long或medium类型的数据),很容易将数字表示为输出。对于浮点数(float或double类型),有时我们需要将其四舍五入到特定的小数位数。例如,如果我们想将52.24568表示为三位小数,需要进行一些预…

    2025年12月17日
    000
  • C++程序:计算使所有礼物数量相等的操作次数

    假设我们有两个数组 A 和 B,每个数组的大小为 n。有n份礼物,我们想把它们送给一些孩子。第 i 份礼物有 A[i] 颗糖果和 B[i] 个橙子。在一次移动过程中,我们可以选择一些礼物并执行以下操作之一 – 从该礼物中取出一颗糖果(如果有); p> 从这份礼物中取出一颗橙子(如果…

    2025年12月17日
    000
  • 两两乘积之和

    集合X = {a, b, c}的成对乘积可以定义为所有可能的集合对乘积的和。集合的成对为Y = {a * a, a * b, a *c, b * b, b * c, c * c},其中乘积是可交换的。因此,集合X的成对乘积是集合Y的元素之和,即aa + ab + ac + bb + bc + cc。…

    2025年12月17日
    000
  • 给定一个字符串,其中字母的表示方式被打乱的数字

    在今天的文章中,我们将深入探讨与C++中字符串操作相关的一个独特问题。这个问题是“在给定字符串中,字母表达式被打乱的数字。” 这个问题可以作为一个很好的练习,来提高你在C++中的字符串操作和数据结构技能。 问题陈述 给定一个字符串,任务是识别其中字母表达方式被打乱的数字。例如,如果输入字符串是&#8…

    2025年12月17日
    000
  • C程序用于计算等比数列的第N项

    Given ‘a’ the First term, ‘r’ the common ratio and ‘n’ for the number of terms in a series. The task is to find the nth term of the series. So, before…

    2025年12月17日
    000
  • 如何使用指针在C语言中计算数组元素的总和?

    指针是一个存储其他变量地址的变量。 考虑以下语句 – int qty = 179; 声明指针 h2> 声明指针的语法如下 – int *p; 这里,’p’是一个指针变量,它保存其他变量的地址。 立即学习“C语言免费学习笔记(深入)”; 指针的初始…

    2025年12月17日
    000
  • 递归程序在C++中检查一个数字是否是回文数

    我们得到一个整数作为输入。目标是使用递归来确定输入数字 Num 是否为回文。 要检查一个数字是否为回文,请反转该数字并检查两个数字是否相同。如果反转后的数等于原数,则为回文。 示例 输入− Num = 34212; 输出− 34212 不是回文! 解释− 如果我们反转 34212,则得到 21243…

    2025年12月17日
    000
  • C程序用于判断给定的数字是否为强数

    一个强数是一个数字,其中各位数字的阶乘之和等于该数字本身。 示例 123!= 1!+2!+3!                    =1+2+6 =9 在这个例子中,123不是一个强数,因为各位数字的阶乘之和不等于该数字本身。 145!=1!+4!+5!             =1+24+120…

    2025年12月17日
    000
  • 如何在C语言中计算浮点数中的位数?

    在此问题中,给出了一个浮点值。我们必须找到它的二进制表示中的设置位的数量。 例如,如果浮点数是0.15625,则有六个设置位。典型的 C 编译器使用单精度浮点表示。所以它看起来像这样。 要转换为位值,我们必须将数字放入一个指针变量中,然后将指针强制转换为 char* 类型数据。然后对每个字节进行一一…

    2025年12月17日
    000
  • 找到通过插入给定数字形成的最小数字

    在给定的数字中插入一个数字意味着在给定的数字中添加一个新的数字,可以是在数字的前面、后面或者中间。我们已经给出了一个数字和一个数字,并且必须以尽可能小的方式将该数字添加到数字中。为了方便插入操作,我们将把数字转换为字符串。此外,给定的数字也可以是负数,因此我们必须考虑这种情况。 示例示例 Input…

    2025年12月17日
    000
  • C++程序计算矩阵对角线之和

    The utilization of 2-dimensional arrays or matrices is extremely advantageous for severalapplications. Matrix rows and columns are used to hold number…

    2025年12月17日
    000
  • 计算给定值的以10为底的对数的C++程序

    各种应用中的自然计算相对需要以 10 为底的对数。对于竞争性考试,有一些快速方法可以记住一些日志值。在编程时,有几种使用库函数计算对数结果的方法以及一些快捷方式。在这篇文章中,我们将介绍几种在 C++ 中计算给定数字的以 10 为底的对数的方法。 使用 log10() 函数 用于确定给定参数的以 1…

    2025年12月17日
    000
  • 计算三个不重叠的子字符串,将它们连接起来形成一个回文串

    简介 在本教程中,我们将详细阐述一种从给定字符串 s 中查找三个不重叠子字符串的方法,并且当所有子字符串组合在一起时,它们形成一个回文。为了解决此任务,我们使用 C++ 编程语言的字符串类功能。 字符串中的回文表示该字符串在向前和向后方向上读起来都相同。回文字符串示例是 Madam。 假设有一个字符…

    2025年12月17日
    000
  • 打印给定数字的乘法表在C中

    程序描述 打印给定数字的乘法表 算法 接受用户提供的任何需要形成乘法的数字 从 I 的值开始乘以给定数 (=1) 将给定数与 I 的值递增,直到 I 值小于或等于12. 示例 /* Program to print the multiplication table of a given number…

    2025年12月17日
    000
  • 使用给定的操作将数组缩减为一个整数,使用C++实现

    给定一个整数变量Number作为输入。让我们考虑一个包含范围在1到Number之间的元素的数组,元素的顺序可以是任意的。如果我们在数组上执行Number-1次操作,操作如下: 我们从数组中选择两个元素A和B 从数组中移除A和B 将A和B的平方和添加到数组中 立即学习“C++免费学习笔记(深入)”; …

    2025年12月17日
    000
  • M个范围切换操作后的二进制数组是什么?

    这里我们会看到一个问题。我们有一个二进制数组。它有n个元素。每个元素要么是 0,要么是 1。最初,所有元素都是 0。现在我们将提供 M 命令。每个命令将包含开始和结束索引。所以 command(a, b) 表示该命令将从位置 a 的元素应用到位置 b 的元素。该命令将切换值。所以它会从 ath 索引…

    2025年12月17日
    000
  • 计算不具有给定前缀的N位数字的数量

    这里的问题是确定长度为N的字符串中包含的字符’0’到’9’的总数,提供一个整数N和一个字符串前缀数组pre[],使得这些字符串中没有任何一个包含提供的前缀。本文的目的是实现一个程序,找到不具有给定前缀的N位数的数量。 在C编程语言中,一组不同的字符串被…

    2025年12月17日
    000
  • C程序计算身体质量指数(BMI)

    给定一个人的体重和身高,任务是找到他的BMI即身体质量指数,并显示出来。 计算身体质量指数需要两个东西: 体重身高 可以使用下面的公式计算BMI: BMI = (质量或体重) / (身高*身高) 其中体重以千克为单位,身高以米为单位 示例 Input 1-: weight = 60.00 Heigh…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信