0

很抱歉在我解决其他问题之前打开另一个主题。这个问题是一个更大的问题。我不知道是否有人会理解我的代码,因为我将它翻译成英文。该程序的工作方式类似于来自互联网的订单列表或类似的东西。您可以添加订单、删除订单、按 ID 或日期排序、保存和加载订单。按日期排序是我的问题。例如,我添加了 2013、2011 和 2012 等日期。当我尝试对它们进行排序时,没有任何反应,它们保持相同的顺序。如果有人理解这一点,请告诉我有什么问题?这是一个学校项目,我需要修复到明天。有人可以帮我吗?

// according = 1 (Date) 2 = (Price)
void sort(int accor)
{
    int i,j,replace=0;
    ORDER *Pom;

    for(i=0;i<Piece-1;i++){
        for(j=0;j<Piece-1;j++){
            if(according == 1){
                if(strcmp(Item[j]->Date, Item[j+1]->Date) > 0) 
                    replace = 1; 
                else 
                    replace = 0;
            }else if(according == 2){
                if(Item[j]->Price > Item[j+1]->Price ) 
                    replace = 1; 
                else 
                    replace = 0;
            }
            if(replace){
                Pom = Item[j];
                Item[j] = Item[j+1];
                Item[j+1] = Pom;
            }
4

1 回答 1

0

将循环更改为如下所示:

for (i = (Piece - 1); i > 0; i--)
{
  for (j = 1; j <= i; j++)
  {
  // compare and swap
  }
}

来源:http ://www.algorithmist.com/index.php/Bubble_sort.c

于 2013-06-13T17:14:58.180 回答