#include <stdio.h>#define N 10
void assort(int a[],int n)
{
//*********************************
int i=0,j=n,m,k,t;
while (i<j);
{
if(a[i]%2==0){
k=i;i++;
if(a[j]%2!=0){ m=j;
t=a[k];
a[k]=a[m];
a[m]=t;
j--;}
else j--;
}
else i++;
}
//=================================
}
int main()
{
int i,a[N];
//freopen("C5_3C.in", "r", stdin);
//freopen("C5_3C.out", "w", stdout);
for (i=0;i<N;i++)
scanf("%d",&a[i]);
//********************************** assort(a,N);
//==================================
for(i=0;i<N;i++)
printf("%d ",a[i]);
return 0;
}
第1个回答 2012-11-25
#include<stdio.h>#define N 100
void swap(int *a,int *b)
{
int tem;
tem=*a,*a=*b,*b=tem;
}
void fun(int a[],int n)
{
int i,j;
i=0;j=n-1;
while(i<j){
while(i<j&&a[i]%2) i++;
while(i<j&&!(a[j]%2))j--;
swap(a+i,a+j);
}
}
int main(){
int a[N],i,n;
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%d",&a[i]);
fun(a,n);
for(i=0;i<n;i++)
printf("%d ",a[i]);
return 0;
}
void swap(int *a,int *b)
{
int tem;
tem=*a,*a=*b,*b=tem;
}
void fun(int a[],int n)
{
int i,j;
i=0;j=n-1;
while(i<j){
while(i<j&&a[i]%2) i++;
while(i<j&&!(a[j]%2))j--;
swap(a+i,a+j);
}
}
int main(){
int a[N],i,n;
scanf("%d",&n);
for(i=0;i<n;i++)
scanf("%d",&a[i]);
fun(a,n);
for(i=0;i<n;i++)
printf("%d ",a[i]);
return 0;
}
第2个回答 2012-11-25
#include <stdio.h>
#define N 10
void assort(int a[],int n)
{
int i=0;
int j=n-1;
int m,k,t;
while(i<j)
{
if(a[i]%2==0)
{
k=i;
if(a[j]%2!=0)
{
m=j;
t=a[k];
a[k]=a[m];
a[m]=t;
j--;
}
else
j--;
}
else
i++;
}
}
int main()
{
int i;
int a[N]={1,2,3,6,8,7,4,5,9,0};
printf("before:\n");
for(i=0;i<N;i++)
{
printf("%d ",a[i]);
}
printf("\n");
/* printf("input %d numbers:\n",N);
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}*/
assort(a,N);
printf("after:\n");
for(i=0;i<N;i++)
{
printf("%d ",a[i]);
}
printf("\n");
return 0;
}
把第一个i++去掉,本回答被网友采纳
#define N 10
void assort(int a[],int n)
{
int i=0;
int j=n-1;
int m,k,t;
while(i<j)
{
if(a[i]%2==0)
{
k=i;
if(a[j]%2!=0)
{
m=j;
t=a[k];
a[k]=a[m];
a[m]=t;
j--;
}
else
j--;
}
else
i++;
}
}
int main()
{
int i;
int a[N]={1,2,3,6,8,7,4,5,9,0};
printf("before:\n");
for(i=0;i<N;i++)
{
printf("%d ",a[i]);
}
printf("\n");
/* printf("input %d numbers:\n",N);
for(i=0;i<N;i++)
{
scanf("%d",&a[i]);
}*/
assort(a,N);
printf("after:\n");
for(i=0;i<N;i++)
{
printf("%d ",a[i]);
}
printf("\n");
return 0;
}
把第一个i++去掉,本回答被网友采纳
第3个回答 2012-11-25
N=10
int a[N]
assort(a,N)
j=N
a[N]越界追问
int a[N]
assort(a,N)
j=N
a[N]越界追问
那怎么改呢
追答assort第二个参数传数组的大小,
assort里j=n改成j=n-1;