将一个数组随机重排

注释部分不要看 那是我试验的经过

#include
#include
#include
#include

using namespace std;


int ashuffle(int *a,int L)//将一个有L个整形数的数组随机重排
{
    int xh[L];
    for(int i=0;i    {
        xh[i]=-1;
    }
    srand( (unsigned)time(NULL) );
    for(int i=0;i    {
        //srand((unsigned int)time(NULL));
        //srand((unsigned int)time(NULL));
//        Sleep(1000);
          int x=rand()%L;
//        x--;

//        randomize();

//      int x=random(L+1);
//        x--;
        while(1)
        {
            if(xh[x]!=-1)
                x=(x+1)%L;
            else
                break;
        }
        xh[x]=i;
    }
    int b[L];
    for(int i=0;i    {
        b[i]=a[i];
    }
    for(int i=0;i    {
        a[xh[i]]=b[i];
    }
}


int main(int argc, char *argv[])
{
  int A[20];
  for(int i=0;i<20;i++)
  {
      A[i]=i+1;
  }
  ashuffle(A,20);
  for(int i=0;i<20;i++)
  {
      cout<  } 
 
  system("PAUSE"); 
  return 0;
}

你可能感兴趣的:(专业)