我的 getNumber() 函数有什么问题?
What's wrong with my getNumber() function?
我正在为类制作一个程序,如果你运行它并输入正数,作业的目的就很清楚了。但是,我的int getNumber();
功能似乎无法正常工作。该函数的目的是收集单个正数并返回它。代码如下:
int getNumber()
{
int number;
cin >> number;
if (number < 0)
{
cout << endl; "Number cannot be negative: Please enter a nonnegative value: ";
cin >> number;
}
else
return (number);
}
如果您需要程序的其余部分,请告诉我。我称之为i = getNumber(); movies = new int[i];
编辑:对不起,我忘了提到问题是它不会打印出cout行,但会正确结束该行。发布后,我立即想起 if-else 是一个条件子句而不是循环并切换了它,但仍然有同样的问题。我没有意识到它仍然会接受负数,因为一旦它无法打印"数字不能为负数......"行,我总是结束程序。我在endl
之后放了一个;
而不是<<
,但感谢您解决了一个我不知道我会遇到的问题。很抱歉第一次没有真正说出问题。
if
条件只有一个分支返回值。 如果输入的第一个数字为负数,则该函数不返回任何内容。
您的编译器应该对此发出警告。
您可能希望将if
替换为重复执行的 while
循环,直到输入可接受的数字:
int getNumber()
{
int number;
cin >> number;
while (number < 0)
{
cout << endl; "Number cannot be negative: Please enter a nonnegative value: ";
cin >> number;
}
return number;
}
代码仅在数字不为负时返回值。我假设这是一个编译器错误。
此外,如果它是一个负数,但用户输入了第二个负数,会发生什么情况。你需要更多这样的东西:
int getNumber()
{
int number;
cin >> number;
while (number < 0)
{
cout << endl; "Number cannot be negative: Please enter a nonnegative value: ";
cin >> number;
}
return number;
}
int getNumber()
{
int number;
cin >> number;
while(number<0) // A while loop will allow you to continually input numbers if the value is negative
{
cout << endl; "Number cannot be negative: Please enter a nonnegative value: ";
cin >> number;
}
return number; // you don't need parenthesis before and after number
}
相关文章:
- 警告处理为错误这里有什么问题
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 当我尝试添加 2 个大字符串时,我无法弄清楚出了什么问题
- 违反const正确性:我应该现实地期待什么问题
- 这个带有模板<类 Vector 的C++代码片段有什么问题>
- 我的逻辑反转字符串中的元音有什么问题?
- 需要以下代码的帮助,下面的代码有什么问题
- 常量公共成员有什么问题?
- 以下代码中的函数模板有什么问题?
- 这个返回元素位置的基于循环的函数有什么问题?
- creat_list2功能有什么问题?
- 格式说明符C++有什么问题
- 任何人都可以告诉我我的 C++ 代码出了什么问题?
- 从 argv[1] 转换为字符 * 字符串后有什么问题?
- 我的堆栈和库存清单程序的结构有什么问题?
- 此工厂功能有什么问题?
- 以下 C++ 代码有什么问题?
- 数组为此合并排序函数提供了正确的输出,但向量给出了不正确的输出.出了什么问题?
- reinterpret_cast,只读访问,简单的可复制类型,会出什么问题?
- 它解决了什么问题,对于非真空初始化,生命周期在初始化之前就开始了