早教吧 育儿知识 作业答案 考试题库 百科 知识分享

C语言冒泡排序法,疑问啊~~~~~~~~~~~~~~~~~#include<stdio.h>#defineN15main(){int*p[N],a[N],i,j,*temp;for(i=0;i<=N-1;i++){scanf("%d",&a[i]);p[i]=&a[i];}for(i=1;i<=N-1;i++){for(j=0;j<=N-1-i;j++)if(a[j]>a[j+1

题目详情
C语言冒泡排序法,疑问啊~~~~~~~~~~~~~~~~~#include<stdio.h> #defineN15 main() {int*p[N],a[N],i,j,*temp; for(i=0;i<=N-1;i++) {scanf("%d",&a[i]); p[i]=&a[i]; } for(i=1;i<=N-1;i++) { for(j=0;j<=N-1-i;j++) if(a[j]>a[j+1]) {temp=p[j]; p[j]=p[j+1]; p[j+1]=temp; } } printf("\n"); for(i=0;i<=N-1;i++) {printf("%d",*p[i]); printf("a[%d]=%d\n",i+1,a[i]); } } 这一段代码为什么不能实现排序?是指针有问题吗,还是其他方面的?
▼优质解答
答案和解析
{int*p,a[N],i,j,temp; for(i=0;ia[j+1]) {*temp=*p[j]; *p[j]=*p[j+1]; *p[j+1]=*temp; 来改动指针的指向,使得a[]数组随之变化来实现冒泡 或者你是这样想 a数组里面的值不变,实现排序*p 那if条件改成 if(*p[j]>*p[j+1]) 这样才能通过指针地址的改变实现对*p数组的排序 a数组的内容不变