C语言数组和指针
/*****用选择法对十个整数按大到小的顺序排序*****/#include "stdio.h"
void sort(int *a,int n);
void main ()
{
int a;
int *arr;
arr=a;
for(;arr<a+10;arr++)
{
scanf("%d",arr);
}
arr=a;
sort(arr,10);
for(;arr<a+10;arr++)
{
printf("%d",*arr);
}
}
void sort(int *a,int n)
{
int *i,*j,temp;
i=a;
j=a+1;
for(i=a;i<a+n;i++)
{
for(j=a+1;j<a+n;j++)
{
if(*i<*j)
{
temp=*i;
*i=*j;
*j=temp;
}
}
}
/*****我输入 1 2 3 4 5 6 7 8 9 0 ,输出结果为啥是9 0 1 2 3 4 5 6 7 8 ,有没有大佬教教我,我看不懂啊啊啊啊啊*****/ 你这冒泡条件写错了吧
for(i=a;i<a+n;i++)
{
for(j=a+1;j<a+n;j++) #include "stdio.h"
void sort(int *a,int n);
void main ()
{
int a;
int *arr;
arr=a;
for(;arr<a+10;arr++)
{
scanf("%d",arr);
}
arr=a;
sort(arr,10);
for(;arr<a+10;arr++)
{
printf("%d ",*arr);
}
}
void sort(int *a,int n)
{
int *i,*j,temp;
i=a;
j=a+1;
for(i=a;i<a+n;i++)
{
// printf("%d\n",*a);
for(j=i+1;j<a+n;j++)//这里改动
{
if(*i<*j)
{
temp=*i;
*i=*j;
*j=temp;
}
}
}
} 冒泡是每次循环去找到最大的数,子循环要从母循环当前的下标/地址加一,所以不是a+1 大马强 发表于 2021-8-5 13:22
感谢感谢 大马强 发表于 2021-8-5 13:32
冒泡是每次循环去找到最大的数,子循环要从母循环当前的下标/地址加一,所以不是a+1
明白了,感谢感谢
页:
[1]