Sử dụng thuật toán Back Track để liệt kê các xâu nhị phân độ dài n (C/C++)

Sử dụng thuật toán Back Track để liệt kê các xâu nhị phân độ dài n (C/C++)

Xem lại lý thuyết thuật toán Back Track

>> Lý thuyết về thuật toán quay lui Back Track

Biểu diễn các xâu nhị phân dưới dạng b1, b2,..., bn, trong đó bi∈{0, 1 }. Thủ tục đệ qui Try(i) xác định bi với các giá trị đề cử cho bi là 0 và 1. Các giá trị này mặc nhiên được chấp nhận mà không cần phải thoả mãn điều kiện gì (do đó bài toán không cần đến biến trạng thái). thủ tục Init khởi tạo giá trị n và biến đếm count. thủ tục kết quả in ra dãy nhị phân tìm được. Chẳng hạn với n =3, cây tìm kiếm lời giải được thể hiện như hình.

Liệt kê các xâu nhị phân độ dài n bằng thuật toán Back Track

Chương trình cài đặt:

#include <stdio.h>

#include <alloc.h>

#include <conio.h>

#include <stdlib.h>

void Result(int *B, int n){

 int i;

 printf("\n ");

 for (i = 1; i <= n; i++)

  printf("%3d", B[i]);

}

void Init(int *B, int n){

 int i;

 for (i = 1; i <= n; i++)

  B[i] = 0;

}

void Try(int i, int *B, int n){

 int j;

 for (j = 0; j <= 1; j++){

  B[i] = j;

  if (i == n) {

   Result(B, n);

  }

  else Try(i + 1, B, n);

 }

}

void main(void){

 int *B, n; clrscr();

 printf("\n Nhap n=");

 scanf("%d", &n);

 B = (int *)malloc(n*sizeof(int));

 Init(B, n);

 Try(1, B, n);

 free(B);

 getch();

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

Tommy 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

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

 
Google chê Facebook là Social Network đã lỗi thời

Google chê Facebook là Social Network đã lỗi thời

Trong một cuộc phỏng vấn mới đây, một giám đốc điều hành của Google gọi đối thủ Facebook của mình là một mạng xã hội đã lỗi thời và gây phiền nhiễu người sử dụng bằng các quảng cáo.

Creating a Workflow for Drupal Users

Tạo phiên làm việc của 1 node type cho Drupal Users

This week's tutorial is the second of a two-parter. We've had several students in our classes looking to build websites with multiple content authors ... blogs, newspapers, university sites and more.

Hướng dẫn viết Conditional CSS for IE10 và IE 11

Hướng dẫn viết Conditional CSS for IE10 và IE 11

While working on recent Drupal projects, I learned that Internet 10 and 11 (IE10-11) no longer support IE conditional comments

Công ty diệt chuột T&C

 

Diet con trung