C语言学习之以指针方式实现冒泡排序

  • 实例要求:
  • 要求利用C语言的库函数 int rand(void)返回一个范围在 2 到200 之间的10个整数值。
  • 利用冒泡排序以降序的方式把这10个整数值进行排序,并输出排序前的10个整数和排序后的10个整数。
  • 代码实现:
#include<stdio.h>
#include<stdlib.h>
//函数声明 

void my_sort(int *a,int n);

//main函数 
int main(int argc,const char *argv[]){
	
	int p[10] = {0};
	
	for(int i = 0;i < 10; i++){
	   //输入2~200的随机数 
	  *(p+i) = rand()%200+2;
	
	}
	
	printf("冒泡排序后:");
	for(int i = 0; i<10;i++){
		
	printf("%d ",*(p+i));	
	}
	
	my_sort(p,10);
	
	printf("\n");
	
	printf("冒泡排序后:");
	for(int i = 0; i<10;i++){
		
	printf("%d ",*(p+i));	
	}
        putchar('\n');
	return 0;
}

//函数定义 
void my_sort(int *a,int n){
	
	int k = 0;
	int j = 0;
	
	for(k = 0;k < n-1;k++ ){
		
		for(j = 0;j < n-1-k;j++){
			
			if(*(a+j) < *(a+j+1)){
				int temp = *(a+j);
				*(a+j) = *(a+j+1);
				*(a+j+1) = temp;
				
			}
			   
		}
	}	
	
} 
  • 运行结果:
冒泡排序后:185 88 179 117 195 137 188 94 51 23 
冒泡排序后:195 188 185 179 137 117 94 88 51 23
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值