我试着用C++编写基本的函数,现在我卡住了。你知道为什么这样不行吗?我想这对更有经验的人来说是显而易见的,但对我来说不是。
liczba_liczb是数组单元数,nieposort是数组。

cout<<"\n\nRozpoczynam sortowanie:";
    for(int i=0;i<liczba_liczb-1;i++){

        for(int j=0;j<liczba_liczb-1-i;j++){

            if(niePosort[j]>niePosort[j+1]){

                cout<<"\n"<<niePosort[j]<<">"<<niePosort[j+1]<<", zamiana.";

                temp = niePosort[j+1];
                niePosort[j+1]=niePosort[j];
                niePosort[j] = temp;
            }
        }

    }

最佳答案

我不明白你说代码不起作用是什么意思。我试过了,效果不错。为了简单起见,我只更改了数组名。

#include <iostream>

int main()
{
   const size_t N = 10;
   int a[] = { 9, 8, 7, 6, 5, 4, 3, 2, 1, 0 };

   for ( size_t i = 0; i < N - 1; i++ )
   {
      for ( size_t j = 0; j < N - 1 - i; j++ )
      {
         if ( a[j] > a[j+1] )
         {
            int temp = a[j+1];
            a[j+1] = a[j];
            a[j] = temp;
         }
      }
   }

   for ( int x : a ) std::cout << x << ' ';
   std::cout << std::endl;
}

输出是
0 1 2 3 4 5 6 7 8 9

这是按升序对数组排序的代码。

10-08 18:59