冒泡排序法示例

本文详细阐述了使用数组作为参数进行排序的过程,包括定义指针、外循环控制比较次数和内循环控制单次比较的元素。通过示例代码演示了如何在C语言中实现数组排序,并展示了排序前后的数组变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include <stdio.h>



// 用数组作形参时 传数组的首地址及数组的长度

void sort(int array[],int len)

{

    //定义一个指针并初始化为空,以保证定义的指针不是野指针以便后续使用

   int * p =NULL;

    

    

    //外循环控制大的比较的次数;

   for (int i =0; i < len-1; i++)

    {

        

        //将指针p指向数组

        p = array;

        

        //内循环控制第i次循环比较的次数

       for (int j =0; j < len-i-1; j++)

        {

            //当前一个元素比较后一个元素大时执行交换,保证前者小

           if (*(p+j) > *(p+j+1))

            {

                //定义一个普通变量,使元素的数据交换(不要交换地址);

               int tmp;

                tmp = *(p+j);// *(p+j) 等价于 p[j]


                *(p+j) = *(p+j+1);

                *(p+j+1) = tmp;

            }

        }

    }

    

}



int main(int argc,constchar * argv[])

{


    // insert code here...

    printf("Hello, World!\n");

    

   int arr[5]= {1,8,5,6};

   sort(arr,5);

   for (int i =0 ;i <5; i++)

    {

       printf("%d",arr[i]);

    }

    

   return0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值