有一个数组 int a[n];要求构造如下的函数
void fun(int *p,int n)
将数组a中的0都移动到末尾,并将非0的元素移动到开始并保证顺序型不变。
例如a原来是1 0 3 4 0 -3 5
经过处理后改为1 3 4 -3 5 0 0
#include<stdio.h>
void fun(int *p,int n){
int i,tmp,j;
for(i=0;i<n-1;i++){
for(j=i+1;j<n;j++){
if(*(p+i)==0){
tmp=*(p+i);
*(p+i)=*(p+j);
*(p+j)=tmp;
}
}
}
}
main(){
int n;
scanf("%d",&n);
int a[n],i;
for(i=0;i<n;i++){
scanf("%d",&a[i]);
}//输入数组
int *p=a;
fun(p,n);
for(i=0;i<n;i++){
printf("%d\t",a[i]);
}
}