| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1011 人关注过本帖
标题:高手们帮帮小弟忙,看看错在哪里,谢谢!!
只看楼主 加入收藏
HK小雨
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2008-4-15
收藏
 问题点数:0 回复次数:15 
高手们帮帮小弟忙,看看错在哪里,谢谢!!
题目是:从键盘输入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 
2008-05-26 22:26
linlei-0835
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2008-5-26
收藏
得分:0 
#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;
      }
}
已经试验了 可以了 你自己看看啦
2008-05-26 22:48
伤心的我
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-5-24
收藏
得分:0 
你的错误太多,
2008-05-26 22:59
伤心的我
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-5-24
收藏
得分:0 
#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;
      }
}
2008-05-26 23:28
StarWing83
Rank: 8Rank: 8
来 自:仙女座大星云
等 级:贵宾
威 望:19
帖 子:3951
专家分:748
注 册:2007-11-16
收藏
得分:0 
t=*(p+i);
      *(p+i)=*(p+k);
      *(p+k)=t;
何必呢老大,直接{int t=p[i];p[i]=p[k];p[k]=t;}不就完了…………虽然指针很强大,但也不是这么用的吧……

专心编程………
飞燕算法初级群:3996098
我的Blog
2008-05-27 00:03
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
凑热闹的
想到了一个新手的算法
数组本身可以逆序输出
起先我不知道数组首尾交换有什么好
某天我发现它有点强大
puts(str);就在这里

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-05-27 00:24
伤心的我
Rank: 1
等 级:新手上路
帖 子:82
专家分:0
注 册:2008-5-24
收藏
得分:0 
脑子不好使呗
2008-05-27 09:10
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
凑热闹的
别相信SW
你这样间接仿问快

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-05-27 09:16
雨中飛燕
Rank: 1
等 级:新手上路
帖 子:765
专家分:0
注 册:2007-10-13
收藏
得分:0 
[bo][un]liyanhong[/un] 在 2008-5-27 09:16 的发言:[/bo]

别相信SW
你这样间接仿问快

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

[color=white]
2008-05-27 09:29
sunkaidong
Rank: 4
来 自:南京师范大学
等 级:贵宾
威 望:12
帖 子:4496
专家分:141
注 册:2006-12-28
收藏
得分:0 
我恶搞下。。呵呵
#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]]
2008-05-27 10:30
快速回复:高手们帮帮小弟忙,看看错在哪里,谢谢!!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.025422 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved