j<=0这个条件导致根本没有循环
应该是j>=0
#include <stdio.h>
void bubbleSort(int arr[], int n) {
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main() {
int arr[] = {5, 2, 8, 3, 1, 9, 4};
int n = sizeof(arr) / sizeof(arr[0]);
bubbleSort(arr, n);
printf("Sorted array: ");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
不知道你这个问题是否已经解决, 如果还没有解决的话:#include <stdio.h> #include <string.h> main() { char str[20][10],t[20],str1[10]; int i,j,n=0; while(1) { scanf("%s",str1); if(str1[0]=='#') { break; } else { strcpy(str[n],str1); n++; } } for(i=0;i<n-1;i++) for(j=0;j<n-i-1;j++) { if(strlen(str[j])>strlen(str[j+1])) { strcpy(t,str[j]); strcpy(str[j],str[j+1]); strcpy(str[j+1],t); } } for(i=0;i<n;i++) { printf("%s ",str[i]); } }
冒泡排序是一种基本的排序算法,它的基本思想是通过多次比较和交换来实现排序。具体步骤如下:
arr = [6, 3, 8, 2, 9, 1]
for i in range(len(arr)):
for j in range(len(arr)-1-i):
if arr[j] < arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
全部代码如下:
arr = [6, 3, 8, 2, 9, 1]
for i in range(len(arr)):
for j in range(len(arr)-1-i):
if arr[j] < arr[j+1]:
arr[j], arr[j+1] = arr[j+1], arr[j]
print(arr)
如果运行结果是原始的数组,那么可能是因为代码中的逻辑错误或者是没有正确实现冒泡排序算法。可以逐步调试代码,查看运行过程中变量的取值,以便快速定位问题所在。