{C語言演算法}排列組合

來源:互聯網
上載者:User

#include <stdio.h>
#include <conio.h>

#define NDEBUG

#include <assert.h>

int print_flag(int flag[],int data[])
{
    int i;
    for(i=0;i<9;i++)   {
        #if 1
        if(1==flag[i])
            printf("%d ",data[i]);
        #else
        printf("%d ",flag[i]);
        #endif
    }

    putchar('\n');
    #if 0
    sleep(1);
    #endif
}

int main(void)
{
    int data[]={0,1,2,3,4,5,6,7,8};
    int flag[9]={0}; //使用標誌位法
    int temp[5]={0}; //預設為0
    int i=0,j=0,k=0; //預設為0

    while(1)
    {
        //------ kernel ------
        flag[0]++;
        for(i=0;i<9;i++)
        {
           if(flag[i]==2){
                flag[i]=0;
                if(i<8)
                    flag[i+1]++;
            }
         }
         //---------------------
         print_flag(flag,data);
         k++;     //count
         for(i=0,j=0;i<9;i++)
            if(flag[i]==1)
                  j++;
          if(j==9) //共9種排列
            break;
     }

     printf(">>%d",k);

    getch();
    return 0;
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.