Bài toán liệt kê các hoán vị của một tập có lặp theo thứ tự từ điển C/C++

Bài toán liệt kê các hoán vị của một tập có lặp theo thứ tự từ điển C/C++

Bài toán: Cho tập X gồm n chữ cái. X = {a,b,c,…} trong đó các chữ cái có thể lặp lại.

Xem qua lý thuyết

>> Giải thuật liệt kê hoán vị - liệt kê hoán vị tiếp theo theo thứ tự từ điển

Hãy liệt kê các hoán vị của tập X trên theo thứ tự từ điển.

[Input]

Có thể có nhiều hơn một test case trong file dữ liệu đầu vào PERMUTATION.INP. Dòng đầu tiên ghi số test case T.

Theo sau là danh sách test case.

Các dòng tiếp theo là string đầu vào.

[OutPut]

Ghi ra file PERMUTATION.OUT liệt kê tất cả các hoán vị theo thứ tự từ điển.

[I/O Example]

Input

2
bbjd
abcd

Output

bbdj ← in the order of b, b, d, and j
bbjd
bdbj
bdjb
bjbd
bjdb ← in the order of b, j, d, and b
dbbj
dbjb
djbb
jbbd
jbdb
jdbb

 

abcd
abdc
acbd
acdb
adbc
adcb
bacd
badc
bcad
bcda
bdac
bdca
cabd
cadb
cbad
cbda
cdab
cdba
dabc
dacb
dbac
dbca
dcab
dcba

Chương trình sinh hoán vị kế tiếp của tập n phần tử có lặp.

#include <cstdio>

#include <iostream>

#include<string.h>

using namespace std;

char str[11];

int n;

void toPermutation(){

          while(true){

                    //print out.

                    for(int index = 0;index <n; index++){

                              cout<<str[index];

                    }

                    cout<<"\n";

                    // find j that arr[j] < arr[j+1]

                    int j = n -2;

                    while(j>=0 && str[j] >= str[j+1]){

                              j--;

                    }

                    if(j == -1) break;

                    // find index on the right that is minimum and greater than arr[j].

                    int minRightIndex = j+1;

                    for(int k=j+2;k<n;k++){

                              if(str[k] <= str[minRightIndex] && str[k] > str[j]){

                                        minRightIndex = k;

                              }

                    }

                    // wrap j and minRightIndex

                    char temp = str[j];

                    str[j] = str[minRightIndex];

                    str[minRightIndex] = temp;

                    //revert arr from j+1 to n

                    for(int loop = 0; loop < (n -1 -j)/2;loop++){

                              char temp = str[j +1 + loop];

                              str[j+1+loop] = str[n- 1 -loop];

                              str[n -1 -loop] = temp;

                    }

                    

          }

}

int main(int argc, char** argv)

{

          int tc, T;

          freopen("PERMUTATION.INP", "r", stdin);

          freopen("PERMUTATION.OUT", "w", stdout);

          cin >> T;

          for(tc = 0; tc < T; tc++)

          {

                    cin>>str;

                    n = strlen(str);

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

                              for(int j=i+1;j<n;j++){

                                        if(str[i] > str[j]){

                                                  char temp = str[i];

                                                  str[i] = str[j];

                                                  str[j] = temp;

                                        }

                              }

                    }

                    toPermutation();

        cout<<"\n";

                    // Print the answer to standard output(screen).

                    

          }

          return 0;//Your program should return 0 on normal termination.
 

}
Bạn thấy bài viết này như thế nào?: 
Average: 10 (2 votes)
Ảnh của Tommy Tran

Tommy Tran owner Express Magazine

Drupal Developer having 9+ year experience, implementation and having strong knowledge of technical specifications, workflow development. Ability to perform effectively and efficiently in team and individually. Always enthusiastic and interseted to study new technologies

  • Skype ID: tthanhthuy
  • Phone/Zalo: (+84) 944 225 212
  • WhatsApp: (+84) 944 225 212
  • Line Messenger: (+84) 944 225 212
  • Email: [email protected]
  • Telegram Messenger: https:/t.me/tommytran0401

Advertisement

 

jobsora

Dich vu khu trung tphcm

Dich vu diet chuot tphcm

Dich vu diet con trung

Quảng Cáo Bài Viết

 
Hướng dẫn xây dựng SaaS business with Drupal

Hướng dẫn xây dựng SaaS business with Drupal

Have you ever thought about building your own Software-as-a-Service (SaaS) business based on Drupal

Hướng dẫn chạy Drupal từ OpenShift from Red Hat

Hướng dẫn chạy Drupal từ OpenShift from Red Hat

OpenShift supports any web applications that run on Red Hat Enterprise Linux. This allows a wide range of languages and frameworks. OpenShift takes care of maintaining the services underlying the application and scaling the application as needed.

Hacker thường dùng 4 phương pháp để hack Wi-Fi

Hacker thường dùng 4 phương pháp để hack Wi-Fi

Khái niệm “hack Wi-Fi” từ lâu đã trở nên quen thuộc đối với giới hacker cũng như những người có ý đồ “xài chùa” mạng của những nhà bên cạnh.

Wordpress Freelancer

 

Wordpress Freelancer