#include<iostream>
using namespace std;
//42.编程实现"冒泡排序算法",将输入的若干整数由小到大(升序)排序输出。
//要求定义一个排序函数,其原型是void bubble(int data[], int length)。
void bubble(int data[],int length){
int i,j,temp;
for(i=0;i<length;i++){
for(j=0;j<length;j++){
if(data[j]>data[j+1]){
temp=data[j];
data[j]=data[j+1];
data[j+1]=temp;
}
}
}
cout<<"排好序后为:"<<endl;
for(i=0;i<length;i++){
cout<<data[i]<<" ";
}
}
int main(){
int data[]={1,3,2,6,5,8,4,9,7};
int length=sizeof(data)/sizeof(data[1]);
bubble(data,length);
}
冒泡排序,数组中没有0,为什么输出的结果总是第一个是0呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- 在野之下 2020-11-29 15:42关注
定义函数的第二个for循环中终止条件改一下改为:
for(j=0;j<length-1;j++){
}
因为当j=length-1时,一维数组不会出现data[length]这种越界的数的
所以下面会提示堆栈破坏
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 5无用 1
悬赏问题
- ¥15 #MATLAB仿真#车辆换道路径规划
- ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
- ¥15 数据可视化Python
- ¥15 要给毕业设计添加扫码登录的功能!!有偿
- ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
- ¥15 微信公众号自制会员卡没有收款渠道啊
- ¥100 Jenkins自动化部署—悬赏100元
- ¥15 关于#python#的问题:求帮写python代码
- ¥20 MATLAB画图图形出现上下震荡的线条
- ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘