如何解决如果我使用“return”,为什么会得到不同的输出?
为什么在递归调用 BubbleSort 函数之前需要使用 return 语句?
没有返回语句:没有输出
void BubbleSort(int arr[],int n,int j)
{
if(n == 1)
return;
if(j == n - 1)
{
BubbleSort(arr,n - 1,0);
}
if(arr[j] > arr[j + 1])
{
swap(arr[j],arr[j + 1]);
}
BubbleSort(arr,n,j + 1);
return;
}
with return 语句:给出正确的输出
void BubbleSort(int arr[],int j)
{
if(n == 1)
return;
if(j == n - 1)
{
return BubbleSort(arr,j + 1);
return;
}
解决方法
通过指定 return
关键字,我们确保程序的控制权将转移到其调用方。
BubbleSort(arr,n - 1,0);
当您执行此操作时,没有 return 关键字,它正在调用 self 并且控件不会返回给它的调用者,因此其余代码也在执行,并且它确实改变了非预期的业务,您可能会得到一些混乱的东西到你的结果。
以下片段可能会帮助您更好地理解它:
if(j == n - 1)
{
BubbleSort(arr,0);
return; // returns to it caller.
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。