在C++中,将给定的四个数字组成的第n个数字的位数

在c++中,将给定的四个数字组成的第n个数字的位数

We need to find the number of digits in the nth number made of given four digits 1, 2, 3, and 4.

The series with the above four digits is as follows

1, 2, 3, 4, 11, 12, 13, 14, 21, 22, 23, 24…

We need to find the number of digits of the nth number from the above series. If you carefully observe the pattern, you will find the following points.

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

There are 4 numbers with digits 1.

There are 16 numbers with digits 2.

The pattern continues as the powers of 4.

Let’s see an example

Input

7

Output

2

The 7th number in the series is 13 and the number of digits in it is 2.

Algorithm

Initialise the number n.Initialise two variables one to store result and another one to store total sum of numbers in the series.Create a loop that increased the iterative variable by the powers of 4.Add the current number to the sum variable.If the total sum is greater than n, then break the loop.Add 1 to the result as next set of number will have one digit extra than previous set of numbers.Return the result.

Implementation

Following is the implementation of the above algorithm in C++

#include using namespace std;int getDigitsCount(int n) {   int i, result = 1, sum = 0;   for (i = 4; ; i *= 4) {      sum += i;      if (sum >= n) {         break;      }      result += 1;   }   return result;}int main() {   int n = 57;   cout << getDigitsCount(n) << endl;   return 0;}

输出

如果你运行上述代码,你将得到以下结果。

3

以上就是在C++中,将给定的四个数字组成的第n个数字的位数的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 20:55:08
下一篇 2025年12月17日 15:45:24

相关推荐

  • 在C语言中的布尔数组谜题

    这是一个基于数组的谜题,需要你将包含两个元素的数组中的所有数字都更改为0。数组的一个元素是0,另一个元素可能是0也可能不是。 要解决这个谜题,程序需要找到非零元素并将其更改为0。 以下是解决布尔数组谜题所需的约束条件 − 允许的操作是补集,其他操作不允许。不允许使用循环和条件语句。也不允许直接赋值。…

    2025年12月17日
    000
  • c语言大小写字母怎么转化

    c语言大小写字母转化的方法:1、tolower()函数,使用for循环来遍历字符串中的每个字符,将每个字符传递给tolower()函数进行转换,并将转换结果赋值给原来的字符,最后打印转换后的字符串;2、toupper()函数,使用for循环来遍历字符串中的每个字符,将每个字符传递给toupper()…

    2025年12月17日
    000
  • 在C语言中,转义序列

    许多编程语言支持一种称为转义序列的概念。当一个字符前面有一个反斜杠()时,它被称为转义序列,并且对编译器有特殊的意义。例如,下面的语句中的 是一个有效的字符,它被称为换行字符 − char ch = ”;在这里,字符n之前有一个反斜杠(),它具有特殊含义,即换行,但请记住反斜杠()只对一些字符具有…

    2025年12月17日
    000
  • 在C语言中编写一个程序来打印菱形图案

    程序描述 钻石图案是简单金字塔图案和倒金字塔图案的组合。 算法 First Row: Display 1Second Row: Display 1,2,3Third Row: Display 1,2,3,4,5Fourth Row: Display 1,2,3,4,5,6,7Fifth Row: D…

    2025年12月17日
    000
  • c语言画皮卡丘代码怎么写

    编写步骤:1、在C语言中安装图形库;2、使用“initgraph”函数初始化图形库,并设置绘图窗口的大小和位置;2、使用“setcolor”函数设置绘图的颜色,使用“circle”函数绘制圆形,使用`arc`函数绘制弧线,使用“ellipse”函数绘制椭圆;3、使用“getch”函数等待用户按下任意…

    2025年12月17日
    000
  • 使用C++移除两个零之间的元素

    在本文中,我们将讨论如何从一个只包含0和1字符的给定字符串中删除两个零之间的元素。最终的字符串不应包含任何被0包围的字符’1’。例如- Input : string = “110010”Output : “11000”Expla…

    2025年12月17日
    000
  • 使用C++编写一个找到数字的程序,其数字的各位数之和为偶数的程序

    能被2整除的整数是偶数。因此在本文中,我们给定了一个数n,我们需要找到第n个数字,其数字之和为偶数。前五个数字的数字之和为偶数的数分别是2、4、6、8和11。例如 − Input : n = 5Output : 11Explanation : First 5 numbers with even su…

    2025年12月17日
    000
  • 如何使用C语言以Pascal三角形的形式打印整数?

    pascal的三角形是以三角形的形式表示整数的一种方法。其中一个著名的表示方法是使用二项式方程。我们可以使用组合和阶乘来实现这一点。 构建Pascal三角形 三角形外的所有值都被视为零(0)。第一行是0 1 0,而只有1在Pascal的三角形中占据一个空间,0是看不见的。第二行是通过添加(0+1)和…

    2025年12月17日
    000
  • 在C语言中编写一个程序来打印实心和空心菱形图案

    程序说明 打印如下所示的实心和空心菱形图案 算法 对于空心菱形 – Accept the Number of Rows for Hollow Rhombus from the UserCreate a Hollow Rhombus containing the same number o…

    2025年12月17日
    000
  • C和C++之间的不兼容性

    在这里,我们将看到C和C++之间的一些不兼容性。一些可以使用C编译器编译的C代码,在C++编译器中无法编译。并且会返回错误。 我们可以使用一种语法来定义函数,该语法在参数列表之后可选择指定参数类型。 示例 #includevoid my_function(x, y)int x;int y; { //…

    2025年12月17日
    000
  • Kruskal的最小生成树算法-贪婪算法在C++中

    生成树是连接所有顶点的有向无向图子图。图中可以存在许多生成树。每个图上的最小生成树(mst)的权重相同或小于所有其他生成树。权重被分配给生成树的边,总和是分配给每个边的权重。由于 v 是图中的顶点数,因此最小生成树的边数为 (v – 1),其中 v 是边数。 使用 Kruskal 算法查…

    2025年12月17日
    000
  • 如何使用C语言中的for循环打印用户选择的一个月份的日历?

    The logic to print a one-month calendar is as follows − for(i=1;i<first;i++) printf(" ");for(i=1;i<=noofdays;i++){ printf("%3d&qu…

    2025年12月17日
    000
  • 在C语言中,bool的使用

    在 C 语言中,没有预定义的 bool 数据类型。我们可以使用枚举创建布尔值。一个枚举将被创建为 bool,然后将 false 和 true 作为枚举的元素。 false 将位于第一个位置,因此它将保留 0,true 将位于第二个位置,因此它将获得值 1。现在我们可以使用它作为数据类型。 示例 #i…

    2025年12月17日
    000
  • 一个用C语言编写的程序,用于检查二叉树是否为二叉搜索树(BST)

    二叉树是一种树形数据结构,每个节点都有两个子节点。这两个子节点被称为左子节点和右子节点。 二叉搜索树(BST)是一种树形结构,其中左子树包含小于根节点的值的节点,右子树包含大于根节点的值的节点。 在这里,我们将检查一个二叉树是否是BST: 为了检查这个,我们需要在二叉树上检查BST条件。对于根节点,…

    2025年12月17日
    000
  • 在C语言中,字符串搜索函数是什么?

    该库还提供了几个字符串搜索函数,如下 – char *strchr (const char *string, intc); 查找字符串中第一次出现的字符 c。 char “strrchr (const char “string, intc); 查找字符串中最后一次…

    2025年12月17日
    000
  • 在C和C++中的未定义行为

    在这里,我们将看到一些C和C++代码,并尝试猜测结果。这些代码将生成一些运行时错误。 1. 除以零的错误是未定义的。 示例代码 #include using namespace std;int main() { int x = 10, y = 0; int z = x / y; cout <&…

    2025年12月17日
    000
  • 使用C语言在数组中插入元素

    我们可以在任意位置插入元素,这意味着我们可以在数组的起始位置、中间、最后或任意位置插入。 在数组中插入元素后,位置或索引位置增加,但并不意味着数组的大小增加。 插入元素的逻辑是− 输入数组的大小 立即学习“C语言免费学习笔记(深入)”; 输入要插入元素的位置 接下来输入您要在该位置插入的数字 for…

    2025年12月17日
    000
  • 在C语言中,Realloc是什么意思?

    c库的内存分配函数void *realloc(void *ptr, size_t size) 尝试重新调整由ptr指向的先前使用malloc或calloc调用分配的内存块。 内存分配函数 内存可以通过以下两种方式进行分配: 一旦在编译时分配了内存,就无法在执行期间更改。要么内存不足,要么内存浪费。 …

    2025年12月17日
    000
  • 使用C++找到模方程的解的数量

    在本文中,我们将解释什么是模方程的​​解,我们还将编写一个程序来查找模方程的多个解。这是基本示例 – Input : X = 30 Y = 2Output : 4, 7, 14, 28Explanation : 30 mod 4 = 2 (equals Y), 30 mod 7 = 2 …

    2025年12月17日
    000
  • 在C语言中,什么是数组的越界索引?

    假设您有一个包含四个元素的数组。那么,数组索引将从0到3,即我们可以访问索引0到3的元素。 但是,如果我们使用大于3的索引,它将被称为索引越界。 如果我们使用越界的数组索引,那么编译器将编译甚至运行。但是,不能保证结果正确。 结果可能不确定,并且会导致许多问题。因此,建议在使用数组索引时要小心。 立…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信