标题:关于快排的一个小问题
取消只看楼主
yiyue123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:78
专家分:78
注 册:2018-6-18
结帖率:100%
已结贴  问题点数:20 回复次数:1 
关于快排的一个小问题
今天想学下快排,到网上翻了翻别人的代码:
程序代码:
void quicksort(int a[],int left,int right)
{
  int i,j;
  int t,temp;
  if(left>right)
    return;
  i=left;
  j=right;
  temp=a[left];
  while(i!=j)
  {
      while(a[j]>=temp&&i<j)
         j--;
      while(a[i]<=temp&&i<j)
         i++;
      if(i<j)
      {
         t=a[i];
         a[i]=a[j];
         a[j]=t;
      }
  }
  a[left]=a[i];
  a[i]=temp;
  quicksort(a,left,i-1);
  quicksort(a,i+1,right);
}

我试着抄了下,不小心抄成了这样:
程序代码:
void quicksort(int a[],int left,int right)
{
  int i,j;
  int t,temp;
  if(left>right)
    return;
  i=left;
  j=right;
  temp=a[left];
  while(a[j]>=temp&&i<j)
    j--;
  while(a[i]<=temp&&i<j)
    i++;
  if(i<j)
    {
      t=a[i];
      a[i]=a[j];
      a[j]=t;
    }
  a[left]=a[i];
  a[i]=temp;
  quicksort(a,left,i-1);
  quicksort(a,i+1,right);
}

结果也能运行,我懵了。
求指教。
搜索更多相关主题的帖子: 快排 int left temp while 
2019-01-31 13:27
yiyue123
Rank: 2
等 级:论坛游民
威 望:1
帖 子:78
专家分:78
注 册:2018-6-18
得分:0 
多谢
2019-02-03 08:30



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




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

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