当前位置: 代码迷 >> C语言 >> 高手们帮帮小弟忙,看看错在哪里,谢谢!!
  详细解决方案

高手们帮帮小弟忙,看看错在哪里,谢谢!!

热度:268   发布时间:2008-05-26 22:26:27.0
高手们帮帮小弟忙,看看错在哪里,谢谢!!
题目是:从键盘输入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  

----------------解决方案--------------------------------------------------------
#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
你这样间接仿问快

你错了!这两种写法没有任何效率上的区别!!

[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]]
----------------解决方案--------------------------------------------------------
  相关解决方案