高手们帮帮小弟忙,看看错在哪里,谢谢!!
题目是:从键盘输入8个数,用选择法案由大到小顺序排列并输出,要求用指针实现我的程序:
#include<stdio.h>
#include<string.h>
void main()
{int a[8],i;
for(i=0;i<8;i++)
scanf("%d",&a[i]);
void puanduan(int *a);
for(i=0;i<8;i++)
printf("%d",a[i]);
}
void puanduan(int *a[]);
{int *p,k,i,t;
p=&a;
for(i=0;i<7;i++)
for(k=i+1,k<7;k++)
if(*(p+i)<*p(p+k))
{t=*(p+i);
*(p+i)=*(p+k);
*(p+k)=t;
}
}
----------------解决方案--------------------------------------------------------
#include<stdio.h>
#include<string.h>
void main()
{ void puanduan(int *a[8]);
int a[8],i;
for(i=0;i<8;i++)
scanf("%d",&a[i]);
puanduan(a);
for(i=0;i<8;i++)
printf("%d",a[i]);
getch();
}
void puanduan(int *a[8])
{
int *p,k,i,t;
p=a;
for(i=0;i<8;i++)
for(k=i+1;k<8;k++)
if(*(p+i)<*(p+k))
{t=*(p+i);
*(p+i)=*(p+k);
*(p+k)=t;
}
}
已经试验了 可以了 你自己看看啦
----------------解决方案--------------------------------------------------------
你的错误太多,
----------------解决方案--------------------------------------------------------
#include<stdio.h>
#include<string.h>
void main()
{void puanduan();
int a[8],i;
for(i=0;i<8;i++)
scanf("%d",&a[i]);
for(i=0;i<8;i++)
printf("%d ",a[i]);
printf("\n");
puanduan(a);
for(i=0;i<8;i++)
printf("%d ",a[i]);
getch();
}
void puanduan(int *p)/*比较选择法是这样用的*/
{int i,k,t;
for(i=0;i<7;i++)
for(k=i+1;k<8;k++)
if(*(p+i)<*(p+k))
{t=*(p+i);
*(p+i)=*(p+k);
*(p+k)=t;
}
}
----------------解决方案--------------------------------------------------------
t=*(p+i);
*(p+i)=*(p+k);
*(p+k)=t;
何必呢老大,直接{int t=p[i];p[i]=p[k];p[k]=t;}不就完了…………虽然指针很强大,但也不是这么用的吧……
----------------解决方案--------------------------------------------------------
凑热闹的
想到了一个新手的算法数组本身可以逆序输出
起先我不知道数组首尾交换有什么好
某天我发现它有点强大
puts(str);就在这里
----------------解决方案--------------------------------------------------------
脑子不好使呗
----------------解决方案--------------------------------------------------------
凑热闹的
别相信SW你这样间接仿问快
----------------解决方案--------------------------------------------------------
[bo][un]liyanhong[/un] 在 2008-5-27 09:16 的发言:[/bo]
别相信SW
你这样间接仿问快
别相信SW
你这样间接仿问快
你错了!这两种写法没有任何效率上的区别!!
[color=white]
----------------解决方案--------------------------------------------------------
我恶搞下。。呵呵
#include<stdio.h>#include<string.h>
#define N 8
int jg(int *b,int k,int n)
{
for(int i=0;i<k;i++)
if(b[i]==n)
return 0;
return 1;
}
void main()
{
int b[N];
int a[N],i;
int flag=0;
for(i=0;i<8;i++)
scanf("%d",&a[i]);
int max=N+1;
for(i=0;i<N;i++)
{
for(int j=0;j<N;j++)
{
if(!flag&&jg(b,i,j))
{ max=j; flag=1;}
if(flag==1&&a[max]<=a[j]&&jg(b,i,j))
{ max=j;}
}
b[i]=max;
flag=0;
}
for(i=0;i<8;i++)
printf("%d ",a[b[i]]);
}
[[it] 本帖最后由 sunkaidong 于 2008-5-27 12:30 编辑 [/it]]
----------------解决方案--------------------------------------------------------