- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一点 Python 编程经验,出于好奇,我开始学习 C,至少是最基础的。在教程中,我找到了一个用于计算阶乘的示例函数,它是这样的:
int factorial(int x)
{
int i;
for(i=1; i < x; i++)
{
x *= i;
}
return x;
}
我还添加了这些行以查看输出:
#include <stdio.h>
int main()
{
int val;
val = factorial(5);
printf("%d\n",val);
return 0;
}
然后我用gcc factor.c -o factor.out
编译了代码,运行……哎呀,结果是-1899959296
,显然有问题.
尝试了几次之后,使用 printf()
打印了 i
和 x
,我弄清楚出了什么问题(我想): 由于 for
循环的条件检查计数器是否小于 x
,并且在每一步 x
变得越来越大,i
总是小于x
,所以循环一直进行下去,估计是x
的值太大时停止(应该与int
,我对各种数据类型还不是很熟悉)。
所以,为了“解决”这个问题,我重写了这个函数:
int factorial(int x)
{
int counter = x;
int number = x;
int i;
for (i=1; i < counter; i++)
{
number *= i;
}
return number;
}
我编译了程序,运行,打印出来的值是120,是正确的。
我稍微搜索了一下 C 中的阶乘函数的示例,发现许多解决方案比我的要好得多,考虑到负数和 long
之类的格式,但所有这些都在某种方式,似乎依赖于两个“主要”变量,很像我的解决方案。
那么,最后一个问题:所提出的示例是错误的,还是我遗漏了什么?这真的让我很困扰,因为如果这样一个简单的例子是公然错误的,我应该质疑其他人的可信度。
最佳答案
是的,的确如此。正是由于您已确定的原因,原始阶乘函数是错误的。您不能将 x
同时用作累加器和循环限制。
在您的版本中,我建议的一项改进是去掉 counter
。由于您不再修改 x
,因此不需要保存它的副本。
int factorial(int x)
{
int number = x;
int i;
for (i=1; i < x; i++)
{
number *= i;
}
return number;
}
如果你反转循环,你可以在没有额外变量的情况下做到这一点。
int factorial(int x)
{
int i;
for (i = x - 1; i > 1; i--)
{
x *= i;
}
return x;
}
不过,我不会这样写。修改输入参数是糟糕的风格。
关于c - C 教程中的这个阶乘函数是错误的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43157639/
我正在做一些关于大 O 表示法的练习题,遇到了这个问题。什么是函数 𝑓(𝑛) = 𝑛^2 + 𝑛 log2(𝑛) + log2(𝑛) 的大 O 阶。展示你的作品。 我的答案是 O(n^2)
是2n吗?只是检查。 最佳答案 术语 B 树的顺序在文献中的定义并不一致。 (例如,参见 terminology section of Wikipedia's article on B-Trees )
我想使用 numpy 创建一个 3 列数组,使得该数组类似于一堆 9x9 2 列数组。这些数组中的每一个都将完全填充有 1、2、3 等。 所以,看立方体的一面,我们看到的是 1,而另一面则是 9。然后
我想将这些数据存储到顺序为 3 (10,20,30,40,50,60,70,80,90) 的 B 树中,我的结果是 并且它与我的书的结果不匹配。可以吗?谢谢:) 最佳答案 这取决于你的意思 Is it
我是 numpy 的新手。创建一个新数组并用一定范围内的随机数填充每个元素的最佳方法是什么? 例如,我想要一个 3×3 数组,其中每个元素都是 0 或 1。 最佳答案 尝试类似的东西 np.rando
我正在尝试学习设计 btree。 以下是开发 5 阶 btree 的值。 1,12,8,2,25,6,14,28,17,7,52,16,48,68,3,26,29,53,55,45,67。 当我插入
我有一个 pandas 数据框,其特征值非常小,数量级为 -322。我正在尝试标准化这些功能,但得到了 ValueError: Input contains NaN, infinity or a va
我是一名优秀的程序员,十分优秀!