递归C++中int值不递增的运行时错误
Run time error for non increasing value of a int recursively C++
这是我的代码。我遇到一个运行时错误。有没有更好的递归方法?目标是:以3作为输入将产生此
- 1 1 1
2 1
3
如果有更好的方法来实现简单的递归,我正在听
#include <iostream>
using namespace std;
int divide(int input,int memory) {
if(memory==input){
cout<<input;
exit(1);
}
cout<<memory<<" ";
int i=memory;
for(i;i<input;i++){
cout<<1<<" ";
}
cout<<endl;
memory++;
divide(input,memory);
}
int main() {
// your code goes here
divide(8,1);
return 0;
}
由于以下行,您只会得到一个运行时错误:
exit(1);
更改为:
exit(0);
顺便说一句,如果你只是想在input==memory
使用时停止该功能
return 0;
EDIT:int divide(int input,int memory) {
这意味着您必须返回一个int
。如果你真的不需要退货,请将其更改为:
void divide(int input,int memory) {
并使用:return;
停止递归
编辑:既然你要求更清洁的实施(在我看来)将是:
void divide(int input,int memory) {
std::vector<int> result(input - memory + 1, 1);
result.front() = memory;
std::copy(result.begin(), result.end(), std::ostream_iterator<int>(std::cout, " "));
std::cout << endl;
if (input < ++memory) return;
divide(input,memory);
}
相关文章:
- 删除指向指针的指针是运行时错误吗
- c++中的指针和运行时错误
- 无法理解此 return 语句的功能,没有它就会发生运行时错误
- 在同一模拟中使用静脉和静脉_ inet内容时出现运行时错误
- 对单向链表进行排序时出现运行时错误
- 为什么此代码存在运行时错误?
- 你能解释一下什么运行时错误是如何解决它的吗?
- 为什么会出现 gettnig 运行时错误:加载类型为"_Bit_type"(stl_bvector.h) 的空指针?
- 为什么程序在 c++ 中迭代 emtpy 向量时会抛出运行时错误
- 运行时错误:引用绑定到类型为"int"的空指针
- 为什么当 vector 为空时会显示运行时错误?
- C++运行时错误与快速排序算法抛出堆栈转储错误
- 运行时错误:矢量下标超出范围:正在检查空集
- 分配给gslice_array会导致运行时错误
- cout 新创建的对象引发运行时错误
- C++在使用std::multimap时出现运行时错误的几率很小
- 运行时错误:引用绑定到类型"int"的未对齐地址0xbebebebebebebec6,这需要 4 个字节对齐 (stl_vector.h)
- 试图找出为什么我会收到运行时错误?
- 迭代二维矢量时发生运行时错误
- 调用 java 的回调() 时应用程序崩溃.由于 detatchThread 而获得运行时错误