标题:很简单的问题。。。可是我真的不会
取消只看楼主
黑色哀伤
Rank: 1
等 级:新手上路
帖 子:18
专家分:8
注 册:2012-2-28
结帖率:100%
 问题点数:0 回复次数:2 
很简单的问题。。。可是我真的不会
很简单的用选择法给数组排序
#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: 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



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-362353-1-1.html




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

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