我正在尝试编写一个函数来计算C++数字的数字根,但在编译后出现错误
I'm trying to write a function that computes the numeric root of a number in C++, but get an error after compiling
int main(){
int sum_digits(int tiv) {
int sum = 0;
while (tiv > 0) {
sum += tiv % 10;
tiv /= 10;
};
return sum;
};
int num_root(int num) {
int root = sum_digit(int num);
while(root > 9) {
sum_digits(int root);
};
return root;
};
return 0;
}
这是我写的代码,第一个函数计算一个数字的数字和。第二个函数使用循环重复计算数字的和,直到获得一个数字(即数字根)。
但当我编译代码时,这就是我得到的
5:29:错误:在‘{’标记(主标记的第一行)之前,这里不允许函数定义
22:2:错误:输入(最后一行)末尾应为"}">
如有指导,我们将不胜感激,提前表示感谢。
正如人们在评论中所指出的,您不应该在这样的另一个函数中定义函数。
int main(){
// This is defined inside of main
int sum_digits(int tiv) {
int sum = 0;
while (tiv > 0) {
我总是鼓励适当的代码缩进,因为这会使这个问题更加明显。
此外,这不是进行函数调用的正确方法:
int root = sum_digit(int num);
您不需要在这里再次包含int
(事实上,这样做在语法上是无效的)——从代码的其余部分可以清楚地看出,num
是int
。
这里也一样:
while(root > 9) {
sum_digits(int root);
};
此外,您实际上并没有对sum_digits
的返回值执行任何操作,因此这实际上不会执行任何操作。它将是一个无限循环(如果root
大于9),因为root
的值永远不会改变,或者循环永远不会运行(如果root
小于9)。
最后一点:为了让这个程序真正做任何事情,你必须从main
方法中调用一些有值的函数。现在,即使你修复了编译错误,程序也不会工作,因为你实际上并没有确定你想要什么值的根,而且你从来没有真正调用过你编写的函数。
在函数中定义函数在c/c++中是不应该做的。我认为gcc支持这一点,但它不符合标准。
只需声明和定义您的函数,而不在其他函数中。如果您想对公共api 隐藏匿名名称空间,请使用匿名名称空间
相关文章:
- 比较并显示使用最小值(a,b)和最大值(a、b)升序排列的4个数字
- 为什么随机数生成器不在void函数中随机化数字,而在main函数中随机化
- 检查输入是否不是整数或数字
- 如何(从固定列表中)选择一个数字序列,该序列将与目标数字相加
- 如何用数字处理log(0)
- 最高有效数字侧的第N位
- 如何获取一个数字的前3位
- 查找最接近的大于当前数字的数字的索引
- 找到两对数字,使它们的乘积的绝对差最小化
- 我想做一个彼此不同但重复出现的数字
- 将数字转换为字母(例如:123 转换为一二三)
- C++如何计算用户输入的数字中的偶数位数
- 如何在C++中确定文本文件中的元素是字符还是数字
- 打印数字图案
- C++问题:用户认为数字1-100,程序提出问题不超过6次即可得到答案。无法正确
- 如何检查一个c++字符串中有多少相同的字符/数字
- 求出有多少个数字是完美平方,而sqrt()是L,R范围内的素数
- 将数字打印成文字
- 当使用比格式支持的精度更高的精度来显示数字时,会写出什么数据
- 在将数字随机生成为数组期间从内存输出随机数的数组