第1个回答 2010-12-09
void sort(int a[],int n,int *s[]) 这里面s是个指针数组相当于int **s 是一个二级指针。sort(x,n,&k);中的&k只是一个一级指针。所以传参数的时候会出错
第2个回答 2010-12-16
#include <stdio.h>
#include <stdlib.h>
void sort(int *a[],int n)
{
int i,j,*t;
for (i=0;i<n;i++)
for (j=i+1;j<n;j++)
if (a[i]>a[j])
{
t=a[i];a[i]=a[j];a[j]=t;
}
}
void sc(int x[],int n)
{
int i;
for (i=0;i<n;i++)
{
printf("%d ",x[i]);
}
}
int main(void)
{
int *x[10],n=10,i;
for (i=0;i<10;i++)
{
scanf("%d",&x[i]);
}
sort(x,n);
sc(x,n);
printf("\n");
return 0;
}
第3个回答 2010-12-09
#include <stdio.h>
#include <stdlib.h>
void sort(int a[],int n)
{
int i,j,t;
for (i=0;i<n;i++)
for (j=0;j<n-i;j++)
if (a[i]>a[j])
{
t=a[i];a[i]=a[j];a[j]=t;
}
}
void sc(int x[],int n)
{
int i;
for (i=0;i<n;i++)
{
printf("%3d",x[i]);
}
}
int main(void)
{
int x[10],n=10,i;
for (i=0;i<10;i++)
{
scanf("%d",&x[i]);
}
sort(x,n);
sc(x,n);
printf("\n");
return 0;
}本回答被提问者和网友采纳
第4个回答 2010-12-10
int main()
{
int a[10];
int *p = a;
int *q;
int start_position;
int num;
int temp;
for( int i = 0; i < 10; i++ )
{
printf( "输入第%d个数:\n", i );
scanf( "%d", p++ );
}
printf( "输入开始位置:\n" );
scanf( "%d", &start_position );
printf( "输入要交换的数字的个数:\n" );
scanf( "%d", &num );
if ( start_position < 1 || num < 0 || start_position + num > 11 )
return 0;
printf( "交换前:\n" );
for ( int i = 0; i < 10; i++ )
printf( "%d ", a[i] );
p = a + start_position - 1;
q = p + num - 1;
for ( p; p != q ; p++, q-- )
{
temp = *p;
*p = *q;
*q = temp;
}
printf( "\n交换后:\n" );
for ( int i = 0; i < 10; i++ )
printf( "%d ", a[i] );
return 0;
}
我试了可以,你自己再试试。
第5个回答 2010-12-09
void sort(int a[],int n,int *s[]) 这里面s是个指针数组相当于int **s 是一个二级指针。sort(x,n,&k);中的&k只是一个一级指针。所以传参数的时候会出错
第6个回答 2010-12-16
#include <stdio.h>
#include <stdlib.h>
void sort(int *a[],int n)
{
int i,j,*t;
for (i=0;i<n;i++)
for (j=i+1;j<n;j++)
if (a[i]>a[j])
{
t=a[i];a[i]=a[j];a[j]=t;
}
}
void sc(int x[],int n)
{
int i;
for (i=0;i<n;i++)
{
printf("%d ",x[i]);
}
}
int main(void)
{
int *x[10],n=10,i;
for (i=0;i<10;i++)
{
scanf("%d",&x[i]);
}
sort(x,n);
sc(x,n);
printf("\n");
return 0;
}
第7个回答 2010-12-09
#include <stdio.h>
#include <stdlib.h>
void sort(int a[],int n)
{
int i,j,t;
for (i=0;i<n;i++)
for (j=0;j<n-i;j++)
if (a[i]>a[j])
{
t=a[i];a[i]=a[j];a[j]=t;
}
}
void sc(int x[],int n)
{
int i;
for (i=0;i<n;i++)
{
printf("%3d",x[i]);
}
}
int main(void)
{
int x[10],n=10,i;
for (i=0;i<10;i++)
{
scanf("%d",&x[i]);
}
sort(x,n);
sc(x,n);
printf("\n");
return 0;
}本回答被提问者和网友采纳
第8个回答 2010-12-10
int main()
{
int a[10];
int *p = a;
int *q;
int start_position;
int num;
int temp;
for( int i = 0; i < 10; i++ )
{
printf( "输入第%d个数:\n", i );
scanf( "%d", p++ );
}
printf( "输入开始位置:\n" );
scanf( "%d", &start_position );
printf( "输入要交换的数字的个数:\n" );
scanf( "%d", &num );
if ( start_position < 1 || num < 0 || start_position + num > 11 )
return 0;
printf( "交换前:\n" );
for ( int i = 0; i < 10; i++ )
printf( "%d ", a[i] );
p = a + start_position - 1;
q = p + num - 1;
for ( p; p != q ; p++, q-- )
{
temp = *p;
*p = *q;
*q = temp;
}
printf( "\n交换后:\n" );
for ( int i = 0; i < 10; i++ )
printf( "%d ", a[i] );
return 0;
}
我试了可以,你自己再试试。