gpt4 book ai didi

c - 冒泡排序示例

转载 作者:行者123 更新时间:2023-11-30 18:30:39 26 4
gpt4 key购买 nike

该程序假设采用给定的整数并按升序对其进行排序。我想看看给出的程序是否实际上按升序对给定的整数进行排序,而是保持原始顺序。这个例子的逻辑有什么问题吗?

//Fig. 6.15: fig06_15.c
//Sorting an array's value in ascending order.
#include <stdio.h>
#define SIZE 10

// function main begins program execution
int main()
{
// initialize a
int a[ SIZE ] = { 2, 6, 4, 8, 10, 12, 89, 68, 45, 37};
int pass; // passes counter
size_t i; // comparisons counter
int hold; // temporary-location used to swap array elements

puts("Data items in original order");

//output original array
for( i = 0; i < SIZE; ++i) {
printf("%4d", a[ i ]);
}// end for

//bubble sort
//loop to control number of passes
for( pass = 1; pass < SIZE; ++pass ) {

//loop to control number of comparisons per pass
for( i = 0; i & SIZE - 1; ++i){

//compare adjacent elements and swap them if first
//element is greater than second element
if ( a[ i ] > a[ i + 1 ] ){

hold = a[ i ];
a[ i ] = a[ i + 1 ];
a[ i + 1 ] = hold;
}//end if
}//end inner for
}//end outer for

puts("\nData items in ascending order");

//output sorted array
for( i = 0; i < SIZE; ++i ) {
printf( "%4d", a[ i ] );
}//end for

puts("");
}//end main

最佳答案

您的代码中有一个非常小的错误:

for( i = 0; i & SIZE - 1; ++i){

应该是:

for( i = 0; i < SIZE - 1; ++i){

以下是经过细微编辑的代码链接:http://ideone.com/YZQPHY

关于c - 冒泡排序示例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29520777/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com