|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
#include <stdio.h>
int main()
{void sort(int x[],int n); //sort函数声明
int i,*p,a[10];
p=a; //指针变量p指向a[0]
printf("please enter 10 integer numbers:");
for(i=0;i<10;i++)
scanf("%d",p++); //输人10个整数
p=a; //指针变量p重新指向a[0]
sort(p,10); //调用sort函数
for(p=a,i=0;i<10;i++)
{printf("%d",*p); //输出排序后的10个数组元素
p++;}
printf("\n");
return 0;
}
void sort(int x[],int n) //定义sort函数,x是形参数组名
{int i,j,k,t;
for(i=0;i<n一1;i++)
{k=i;
for(j=i+1;j<n;j++)
if(x[j]>x[k])k=j;
if(k!=i)
{t=x[i];x[i]=x[k];x[k]=t}
}
}
最后倒数第四行if(k!=i)不要行不行,为什么?前面已交待k=i,后面为什么还要k!=i,这不是自相矛盾吗?能不能写出定义sort函数的每一步注释
本帖最后由 jackz007 于 2024-4-18 22:06 编辑
- #include <stdio.h>
- // 函数只要定义在前,调用在后,在调用前就不用特意声明
- void sort(int * x , int n)
- {
- int i , j , k , t ;
- for(i = 0 ; i < n - 1 ; i ++)
- {
- k = i ;
- for(j = i + 1 ; j < n ; j ++) if(* (x + j) > * (x + k)) k = j ;
- if(k != i)
- {
- t = * (x + i) ;
- * (x + i) = * (x + k) ;
- * (x + k) = t ;
- }
- }
- }
- int main(void)
- {
- int i , * p , a[10] ;
- printf("please enter 10 integer numbers:") ;
- for(p = a , i = 0 ; i < 10 ; i ++) scanf("%d" , p + i) ;
- sort(p , 10) ;
- printf("%d" , * p) ;
- for(i = 1 ; i < 10 ; i ++) printf(", %d" , * (p + i)) ;
- printf("\n") ;
- return 0 ;
- }
复制代码
编译、运行实况:
- D:\[exercise]\C>g++ -o x x.c
- D:\[exercise]\C>x
- please enter 10 integer numbers:7 3 8 5 1 2 6 9 4 0
- 9, 8, 7, 6, 5, 4, 3, 2, 1, 0
- D:\[exercise]\C>
复制代码
|
|