| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 363 人关注过本帖
标题:很简单的问题。。。可是我真的不会
只看楼主 加入收藏
黑色哀伤
Rank: 1
等 级:新手上路
帖 子:18
专家分:8
注 册:2012-2-28
结帖率:100%
收藏
 问题点数:0 回复次数:5 
很简单的问题。。。可是我真的不会
很简单的用选择法给数组排序
#include<stdio.h>
void main()
{
void sort(int array[],int n);
int a[10],i;
printf("enter the array\n");
for(i=0;i<10;i++)
  scanf("%d",&a[i]);
sort(a,10);
       printf("the sorted array:\n");
for(i=0;i<10;i++)
       printf("%5d",a[i]);
printf("\n");
}

void sort(int array[],int n)
{
   int i,j,k,t;
   for(i=0;i<n-1;i++)
   {
      k=i;
      for(j=i+1;j<n;j++)
          if(array[j]<array[k])
              k=j;
          t=array[k];array[k]=array[i];array[i]=t;   
   }
}

可是在函数部分,
void sort(int array[],int n)
{
   int i,j,k,t;
   for(i=0;i<n-1;i++)
   {
      k=i;
      for(j=i+1;j<n;j++)
          if(array[j]<array[k])
              k=j;
          t=array[k];array[k]=array[i];array[i]=t;   
   }
}

这一块,为什么不能改成
void sort(int array[],int n)
{
   int i,j,k,t;
   for(i=0;i<n-1;i++)
   {
      for(j=i+1;j<n;j++)
          if(array[j]<array[i])
       t=array[i];array[i]=array[j];array[j]=t;   
   }
}

直接换值,不用中间变量k不行吗?我想了很久了,真的想不通

搜索更多相关主题的帖子: void include 
2012-03-06 13:05
于祥
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:蒙面侠
威 望:5
帖 子:1047
专家分:4132
注 册:2011-4-24
收藏
得分:0 
能改
void sort(int array[],int n)
 {
    int i,j,k,t;
    for(i=0;i<n-1;i++)
    {
       for(j=i+1;j<n;j++)
           if(array[j]<array[i])
       { t=array[i];array[i]=array[j];array[j]=t;} //加{}就行  
    }
 }

最基础的往往是你最容易忽略的!
2012-03-06 13:30
icysky
Rank: 5Rank: 5
来 自:心灵世界
等 级:职业侠客
威 望:1
帖 子:172
专家分:399
注 册:2011-5-17
收藏
得分:0 
前者   只是记录了内循环一轮的最大者的索引
而你的方式   进行了内循环一轮*3次的赋值操作     
效率上没有前者高

不管怎么走、总有一个终点...
2012-03-06 14:25
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:0 
去看看  qsort   它真的很给力

                                         
===========深入<----------------->浅出============
2012-03-06 14:47
黑色哀伤
Rank: 1
等 级:新手上路
帖 子:18
专家分:8
注 册:2012-2-28
收藏
得分:0 
回复 2楼 于祥
谢谢你!我知道是怎么回事了,基础真的很重要啊
2012-03-06 16:04
黑色哀伤
Rank: 1
等 级:新手上路
帖 子:18
专家分:8
注 册:2012-2-28
收藏
得分:0 
回复 3楼 icysky
一开始没怎么理解前面的算法,现在总算明白了。。。
2012-03-06 16:06
快速回复:很简单的问题。。。可是我真的不会
数据加载中...
 
   



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

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