#include <bits/stdc++.h>
using namespace std;
#define MASK(i) (1LL<<(i))
#define BIT(n,i) ((n>>i)&1)
#define SQR(n) (1LL*n*n)
const int INF = 1e9 + 7 ;
template < class _, class __>
bool minimize( _ & x, const __ y) {
if ( x > y) {
x = y;
return true ;
} else return false ;
}
template < class _, class __>
bool maximize( _ & x, const __ y) {
if ( x < y) {
x = y;
return true ;
} else return false ;
}
const int N = 63 ; // Số tỉnh nước Việt Nam
const int MaxM = 35 ; // Số lượng tỉnh tối đa sau khi sáp nhập
const int Log = 16 ; // Số lượng tỉnh cần quản lí trong một trạng thái
const long long Min_Population = 1200000 ;
const int Min_Area = 6500 ;
const int Max_Area = 25000 ;
string Province[ N] = { "Lang Son" , "Quang Ninh" , "Hai Duong" , "Hai Phong" , "Cao Bang" ,
"Bac Kan" , "Thai Nguyen" , "Bac Giang" , "Bac Ninh" , "Hung Yen" ,
"Thai Binh" , "Ha Giang" , "Tuyen Quang" , "Vinh Phuc" , "Ha Noi" ,
"Ha Nam" , "Nam Dinh" , "Lao Cai" , "Yen Bai" , "Phu Tho" ,
"Hoa Binh" , "Ninh Binh" , "Lai Chau" , "Dien Bien" , "Son La" ,
"Thanh Hoa" ,"Nghe An" , "Ha Tinh" , "Quang Binh" , "Quang Tri" ,
"Hue" , "Da Nang" , "Quang Nam" , "Kom Tum" , "Quang Ngai" ,
"Gia Lai" , "Binh Dinh" , "Dak Lak" , "Phu Yen" , "Khanh Hoa" ,
"Ninh Thuan" , "Lam Dong" , "Dak Nong" , "Binh Phuoc" , "Binh Thuan" ,
"Dong Nai" , "Binh Duong" , "Tay Ninh" , "Sai Gon" , "BRVT" ,
"Long An" , "Tien Giang" , "Dong Thap" , "Ben Tre" , "Tra Vinh" ,
"Vinh Long" , "Can Tho" , "An Giang" , "Kien Giang" , "Hau Giang" ,
"Soc Trang" , "Bac Lieu" , "Ca Mau" } ;
int Real_ID[ N] = {
35 , 47 , 25 , 26 , 13 , 3 , 53 , 2 , 5 , 29 , 52 , 21 , 59 , 61 , 23 , 22 , 38 , 36 , 62 , 42 ,
28 , 40 , 33 , 17 , 50 , 54 , 39 , 24 , 44 , 48 , 55 , 14 , 45 , 32 , 46 , 20 , 10 , 15 , 43 , 30 ,
41 , 34 , 16 , 8 , 9 , 18 , 7 , 51 , 57 , 1 , 37 , 56 , 19 , 6 , 58 , 60 , 12 , 0 , 31 , 27 ,
49 , 4 , 11
} ;
vector< int > Edge[ N] = {
{ 1 , 7 , 6 , 5 , 4 } , // 0 - Lang Son
{ 3 , 2 , 7 , 0 } , // 1 - Quang Ninh
{ 1 , 3 , 7 , 8 , 9 , 10 } , // 2 - Hai Duong
{ 1 , 2 , 10 } , // 3 - Hai Phong
{ 0 , 5 , 12 , 11 } , // 4 - Cao Bang
{ 0 , 6 , 12 ,4 } , // 5 - Bac Kan
{ 0 ,7 ,14 ,13 ,12 ,5 } , // 6 - Thai Nguyen
{ 0 ,1 ,2 ,8 ,14 ,6 } , // 7 - Bac Giang
{ 7 ,2 ,9 ,14 } , // 8 - Bac Ninh
{ 8 ,2 ,10 ,15 ,14 } , // 9 - Hung Yen
{ 3 ,2 ,9 ,15 ,16 } , // 10 - Thai Binh
{ 4 ,12 ,17 } , // 11 - Ha Giang
{ 4 ,5 ,6 ,13 ,19 ,18 ,11 } , // 12 - Tuyen Quang
{ 6 ,14 ,19 ,12 } , // 13 - Vinh Phuc
{ 6 ,7 ,8 ,9 ,15 ,20 ,19 ,13 } , // 14 - Ha Noi
{ 9 ,10 ,16 ,21 ,20 ,14 } , // 15 - Ha Nam
{ 10 ,15 ,21 } , // 16 - Nam Dinh
{ 11 ,18 ,22 } , // 17 - Lao Cai
{ 12 ,19 ,24 ,22 } , // 18 - Yen Bai
{ 12 ,13 ,14 ,20 ,24 ,18 } , // 19 - Phu Tho
{ 14 ,15 ,21 ,25 ,24 ,19 } , // 20 - Hoa Binh
{ 15 ,16 ,20 ,25 } , // 21 - Ninh Binh
{ 17 ,18 ,24 } , // 22 - Lai Chau
{ 24 } , // 23 - Dien Bien
{ 23 ,22 ,18 ,19 ,20 ,25 } , // 24 - Son La
{ 21 ,20 ,24 ,26 } , // 25 - Thanh Hoa
{ 25 ,27 } , // 26 - Nghe An
{ 26 , 28 } , // 27 - Ha Tinh
{ 27 , 29 } , // 28 - Quang Binh
{ 28 , 30 } , // 29 - Quang Tri
{ 29 , 31 , 32 } , // 30 - Hue
{ 30 , 32 } , // 31 - Da Nang
{ 30 , 31 , 33 , 34 } , // 32 - Quang Nam
{ 32 , 35 } , // 33 - Kom Tum
{ 32 , 36 } , // 34 - Quang Ngai
{ 33 , 36 , 37 } , // 35 - Gia Lai
{ 34 , 35 , 38 } , // 36 - Binh Dinh
{ 35 , 38 , 41 , 42 } , // 37 - Dak Lak
{ 36 , 37 , 39 } , // 38 - Phu Yen
{ 38 , 40 , 41 } , // 39 - Khanh Hoa
{ 39 , 41 , 44 } , // 40 - Ninh Thuan
{ 37 , 39 , 40 , 42 , 44 , 43 , 45 } , // 41 - Lam Dong
{ 37 , 41 , 43 } , // 42 - Dak Nong
{ 41 , 42 , 45 , 46 , 47 } , // 43 - Binh Phuoc
{ 40 , 41 , 45 , 49 } , // 44 - Binh Thuan
{ 44 ,41 ,43 ,49 ,48 ,46 } , // 45 - Dong Nai
{ 43 ,47 ,48 ,45 } , // 46 - Binh Duong
{ 43 , 46 , 48 , 50 } , // 47 - Tay Ninh
{ 47 ,46 ,45 ,49 ,50 } , // 48 - Sai Gon
{ 44 , 45 , 48 } , // 49 - BRVT
{ 47 , 48 , 51 , 52 } , // 50 - Long An
{ 53 , 55 , 52 , 50 } , // 51 - Tien Giang
{ 50 , 51 , 55 , 56 , 57 } , // 52 - Dong Thap
{ 51 , 54 , 55 } , // 53 - Ben Tre
{ 53 , 55 , 60 } , // 54 - Tra Vinh
{ 53 , 51 , 52 , 54 , 56 , 59 , 60 } , // 55 - Vinh Long
{ 52 , 55 , 57 , 58 , 59 } , // 56 - Can Tho
{ 52 , 56 , 58 } , // 57 - An Giang
{ 56 , 57 , 59 , 61 , 62 } , // 58 - Kien Giang
{ 55 , 56 , 60 , 61 , 58 } , // 59 - Hau Giang
{ 54 , 55 , 59 , 61 } , // 60 - Soc Trang
{ 60 , 59 , 58 , 62 } , // 61 - Bac Lieu
{ 58 , 61 } // 62 - Ca Mau
} ;
/*
Khác với danh sách kề đã liệt kê ở câu 3: Một số cặp đỉnh sẽ không được coi
không kề nhauvì đường giáp ranh giữa hai tỉnh khá nhỏ.
Quãng Ngãi - Gia Lai
TP HCM - Tiền Giang
Đường đi hiểm trở
// if (IsAppear(33,ds) && IsAppear(34,ds)) return false;
// if (IsAppear(22,ds) && IsAppear(23,ds)) return false;
// if (IsAppear(18,ds) && IsAppear(11,ds)) return false;
// if (IsAppear(35,ds) && IsAppear(38,ds)) return false;
// if (IsAppear(37,ds) && IsAppear(39,ds)) return false;
*/
int Area[ N] = {
8310 , // Lang Son
6208 , // Quang Ninh
1668 , // Hai Duong
1527 , // Hai Phong
6700 , // Cao Bang
4860 , // Bac Kan
3522 , // Thai Nguyen
3896 , // Bac Giang
823 , // Bac Ninh
930 , // Hung Yen
1585 , // Thai Binh
7928 , // Ha Giang
5868 , // Tuyen Quang
1236 , // Vinh Phuc
3360 , // Ha Noi
862 , // Ha Nam
1669 , // Nam Dinh
6364 , // Lao Cai
6893 , // Yen Bai
3535 , // Phu Tho
4590 , // Hoa Binh
1412 , // Ninh Binh
9069 , // Lai Chau
9540 , // Dien Bien
14110 , // Son La
11115 , // Thanh Hoa
16486 , // Nghe An
5994 , // Ha Tinh
7999 , // Quang Binh
4701 , // Quang Tri
4947 , // Hue
1285 , // Da Nang
10575 , // Quang Nam
9677 , // Kom Tum
5155 , // Quang Ngai
15510 , // Gia Lai
6066 , // Binh Dinh
13070 , // Dak Lak
5026 , // Phu Yen
5200 , // Khanh Hoa
3356 , // Ninh Thuan
9781 , // Lam Dong
6509 , // Dak Nong
6874 , // Binh Phuoc
7943 , // Binh Thuan
5864 , // Dong Nai
2695 , // Binh Duong
4042 , // Tay Ninh
2095 , // Sai Gon
1983 , // BRVT
4495 , // Long An
2556 , // Tien Giang
3382 , // Dong Thap
2380 , // Ben Tre
2391 , // Tra Vinh
1526 , // Vinh Long
1440 , // Can Tho
3537 , // An Giang
6353 , // Kien Giang
1622 , // Hau Giang
3298 , // Soc Trang
2668 , // Bac Lieu
5275 // Ca Mau
} ;
int Population[ N] = {
813978 , // Lang Son
1393702 , // Quang Ninh
1971326 , // Hai Duong
2121841 , // Hai Phong
555809 , // Cao Bang
328609 , // Bac Kan
1361474 , // Thai Nguyen
1950615 , // Bac Giang
1543529 , // Bac Ninh
1313798 , // Hung Yen
1888184 , // Thai Binh
908263 , // Ha Giang
820054 , // Tuyen Quang
1221803 , // Vinh Phuc
8685607 , // Ha Noi
892755 , // Ha Nam
1892427 , // Nam Dinh
787066 , // Lao Cai
863338 , // Yen Bai
1540608 , // Phu Tho
892373 , // Hoa Binh
1027030 , // Ninh Binh
494626 , // Lai Chau
653422 , // Dien Bien
1327430 , // Son La
3760650 , // Thanh Hoa
3470988 , // Nghe An
1329365 , // Ha Tinh
924169 , // Quang Binh
658619 , // Quang Tri
1177624 , // Hue
1269070 , // Da Nang
1539468 , // Quang Nam
598201 , // Kom Tum
1256952 , // Quang Ngai
1630311 , // Gia Lai
1515422 , // Binh Dinh
1944821 , // Dak Lak
883298 , // Phu Yen
1267443 , // Khanh Hoa
609820 , // Ninh Thuan
1361129 , // Lam Dong
692896 , // Dak Nong
1060448 , // Binh Phuoc
1266240 , // Binh Thuan
3341716 , // Dong Nai
2858815 , // Binh Duong
1201736 , // Tay Ninh
9521886 , // Sai Gon (TP. HCM)
1192863 , // BRVT
1753041 , // Long An
1795251 , // Tien Giang
1600963 , // Dong Thap
1305281 , // Ben Tre
1022887 , // Tra Vinh
1035362 , // Vinh Long
1268514 , // Can Tho
1911002 , // An Giang
1763826 , // Kien Giang
728924 , // Hau Giang
1203705 , // Soc Trang
929439 , // Bac Lieu
1210843 // Ca Mau
} ;
int GRDP[ N] = {
50 , // Lang Son
348 , // Quang Ninh
212 , // Hai Duong
446 , // Hai Phong
25 , // Cao Bang
19 , // Bac Kan
167 , // Thai Nguyen
207 , // Bac Giang
232 , // Bac Ninh
160 , // Hung Yen
71 , // Thai Binh
36 , // Ha Giang
50 , // Tuyen Quang
173 , // Vinh Phuc
1430 , // Ha Noi
56 , // Ha Nam
113 , // Nam Dinh
77 , // Lao Cai
49 , // Yen Bai
107 , // Phu Tho
72 , // Hoa Binh
99 , // Ninh Binh
31 , // Lai Chau
32 , // Dien Bien
77 , // Son La
319 , // Thanh Hoa
217 , // Nghe An
113 , // Ha Tinh
60 , // Quang Binh
54 , // Quang Tri
80 , // Hue
151 , // Da Nang
129 , // Quang Nam
41 , // Kom Tum
133 , // Quang Ngai
111 , // Gia Lai
131 , // Binh Dinh
141 , // Dak Lak
63 , // Phu Yen
129 , // Khanh Hoa
60 , // Ninh Thuan
13 , // Lam Dong
56 , // Dak Nong
115 , // Binh Phuoc
121 , // Binh Thuan
494 , // Dong Nai
520 , // Binh Duong
124 , // Tay Ninh
1778 , // Sai Gon (TP. Ho Chi Minh)
417 , // BRVT
189 , // Long An
137 , // Tien Giang
124 , // Dong Thap
74 , // Ben Tre
97 , // Tra Vinh
84 , // Vinh Long
133 , // Can Tho
127 , // An Giang
144 , // Kien Giang
68 , // Hau Giang
80 , // Soc Trang
66 , // Bac Lieu
88 // Ca Mau
} ;
int trace[ N] [ MaxM] [ MASK( Log) ] ;
int f[ N] [ MaxM] [ MASK( Log) ] ;
int sumGRDP = 0 ;
void prepare( ) {
for ( int i= 0 ; i< N; i++ ) {
for ( int j= 0 ; j< MASK( Log) ; j++ ) {
for ( int m= 0 ; m< MaxM; m++ ) {
f[ i] [ m] [ j] = INF; // Đặt tất cả giá trị về dương vô cùng vì hàm mục tiêu là MIN
trace[ i] [ m] [ j] = 0 ;
}
}
}
f[ 0 ] [ 0 ] [ 0 ] = 0 ;
}
bool IsAppear( int u,vector< int > & ds) {
// Kiểm tra đỉnh thứ u có nằm trong cụm tỉnh [ds] không
for ( int x : ds) {
if ( x == u) return true ;
}
return false ;
}
bool Check( vector< int > ds) {
//Kiểm tra khả năng sáp nhập của cụm tỉnh [ds]
// Cao Bang không sáp nhập với tỉnh nào khác
if ( IsAppear( 4 ,ds) ) return ds.size ( ) == 1 ;
// Hà Nội sáp nhập với nhiều nhất 1 tỉnh
if ( IsAppear( 14 ,ds) ) return ds.size ( ) <= 2 ;
// Các cặp tỉnh không thể sáp nhập vì vấn đề về giao thông
// if (IsAppear(33,ds) && IsAppear(34,ds)) return false;
// if (IsAppear(22,ds) && IsAppear(23,ds)) return false;
// if (IsAppear(18,ds) && IsAppear(11,ds)) return false;
// if (IsAppear(35,ds) && IsAppear(38,ds)) return false;
// if (IsAppear(37,ds) && IsAppear(39,ds)) return false;
// Xét các điều kiện về diện tích và dân số
int Sum_Area = 0 ;
long long Sum_Population = 0 ;
for ( int x : ds) {
Sum_Area + = Area[ x] ;
Sum_Population + = Population[ x] ;
}
return Sum_Area >= Min_Area && Sum_Population >= Min_Population && Sum_Area <= Max_Area;
}
int SumGRDP( vector< int > & ds) {
int sum = 0 ;
for ( int x : ds) {
sum + = GRDP[ x] ;
}
return sum;
}
void Push( int pos,int m,int OldMask,vector< int > ds) {
// Cập nhật giá trị tối ưu và lưu vết cho trạng thái mới khi sáp nhập cụm tỉnh [ds]
if ( ! Check( ds) ) return ;
for ( int x : ds) if ( BIT( OldMask,x - pos) ) return ;
int NewMask = OldMask;
for ( int x : ds) NewMask | = MASK( x - pos) ;
if ( minimize( f[ pos] [ m+ 1 ] [ NewMask] ,f[ pos] [ m] [ OldMask] + SQR( SumGRDP( ds) ) ) ) {
trace[ pos] [ m+ 1 ] [ NewMask] = 0 ;
for ( int x : ds) trace[ pos] [ m+ 1 ] [ NewMask] | = MASK( x- pos) ;
}
}
void Update_To_Next_Province( int pos) {
//Cập nhật cửa sổ để xét tỉnh tiếp theo
for ( int m= 0 ; m< MaxM; m++ ) {
for ( int mask= 0 ; mask< MASK( Log) ; mask++ ) {
if ( BIT( mask,0 ) && f[ pos] [ m] [ mask] < INF) minimize( f[ pos+ 1 ] [ m] [ mask>> 1 ] ,f[ pos] [ m] [ mask] ) ;
}
}
}
void sol( ) {
// Quy hoạch động bitmask, duyệt theo ý tưởng đã nêu
for ( int x= 0 ; x< N; x++ ) {
for ( int m= 0 ; m< MaxM; m++ ) {
for ( int mask= 0 ; mask< MASK( Log) ; mask++ ) {
if ( BIT( mask,0 ) || f[ x] [ m] [ mask] >= INF) continue ;
Push( x,m,mask,{ x} ) ; // tỉnh x không sáp nhập
for ( int y: Edge[ x] ) {
if ( y <= x) continue ;
Push( x,m,mask,{ x,y} ) ; // tỉnh x sáp nhập với 1 tỉnh
// Tỉnh x sáp nhập với 2 tỉnh
for ( int z: Edge[ y] ) {
if ( z <= x) continue ;
Push( x,m,mask,{ x,y,z} ) ;
}
for ( int z: Edge[ x] ) {
if ( z <= x || z == y) continue ;
Push( x,m,mask,{ x,y,z} ) ;
}
}
}
}
if ( x == N - 1 ) continue ;
// Cập nhật cửa sổ tiếp theo
Update_To_Next_Province( x) ;
}
// Đặt S = sumGRDP^2
for ( int i= 0 ; i< N; i++ ) sumGRDP + = GRDP[ i] ;
int S = SQR( sumGRDP) ;
int M = 0 ; // Lượng tỉnh sao cho phương án tối ưu nhất
for ( int i= 0 ; i< MaxM; i++ ) {
if ( f[ N- 1 ] [ i] [ 1 ] >= INF) continue ; // Nếu trường hợp số tỉnh là i không có phương án thì bỏ qua
if ( M == 0 ) M = i; // Tạo cho M giá trị ban đầu
// Lấy sổ lượng tối ưu cho hàm mục tiêu giữa M và i
if ( 1LL* ( i* f[ N- 1 ] [ i] [ 1 ] - S) * SQR( M) < 1LL* ( M* f[ N- 1 ] [ M] [ 1 ] - S) * SQR( i) ) {
M = i;
}
}
// Truy vết
int pos = N- 1 ;
int mask = 1 ;
while ( M ! = 0 ) {
if ( trace[ pos] [ M] [ mask] == 0 ) {
pos-- ;
mask = mask << 1 | 1 ;
}
else {
int tmpp = trace[ pos] [ M] [ mask] ;
for ( int i= 0 ; i< Log; i++ ) {
if ( BIT( tmpp,i) ) {
cout << Province[ i+ pos] << ' ' ;
mask ^ = MASK( i) ;
}
}
M-- ;
cout << '\n ' ;
}
}
}
int main( ) {
// freopen("YeuCau_6_MoTa.out","w",stdout);
prepare( ) ;
sol( ) ;
}
#include <bits/stdc++.h>
using namespace std;

#define MASK(i) (1LL<<(i))
#define BIT(n,i) ((n>>i)&1)
#define SQR(n) (1LL*n*n)

const int INF = 1e9+7;

template<class _, class __>
    bool minimize(_ &x, const __ y){
        if(x > y){
            x = y;
            return true;
        } else return false;
    }
template<class _, class __>
    bool maximize(_ &x, const __ y){
        if(x < y){
            x = y;
            return true;
        } else return false;
    }

const int N = 63; // Số tỉnh nước Việt Nam
const int MaxM = 35; // Số lượng tỉnh tối đa sau khi sáp nhập
const int Log = 16; // Số lượng tỉnh cần quản lí trong một trạng thái
const long long Min_Population = 1200000;
const int Min_Area = 6500;
const int Max_Area = 25000;

string Province[N] = {"Lang Son", "Quang Ninh", "Hai Duong", "Hai Phong", "Cao Bang",
                "Bac Kan", "Thai Nguyen", "Bac Giang", "Bac Ninh", "Hung Yen",
                "Thai Binh", "Ha Giang", "Tuyen Quang", "Vinh Phuc", "Ha Noi",
                "Ha Nam", "Nam Dinh", "Lao Cai", "Yen Bai", "Phu Tho",
                "Hoa Binh", "Ninh Binh", "Lai Chau", "Dien Bien", "Son La",
                "Thanh Hoa","Nghe An", "Ha Tinh", "Quang Binh", "Quang Tri",
                "Hue", "Da Nang", "Quang Nam", "Kom Tum", "Quang Ngai",
                "Gia Lai", "Binh Dinh", "Dak Lak", "Phu Yen", "Khanh Hoa",
                "Ninh Thuan", "Lam Dong", "Dak Nong", "Binh Phuoc", "Binh Thuan",
                "Dong Nai", "Binh Duong", "Tay Ninh", "Sai Gon", "BRVT",
                "Long An", "Tien Giang", "Dong Thap", "Ben Tre", "Tra Vinh",
                "Vinh Long", "Can Tho", "An Giang", "Kien Giang", "Hau Giang",
                "Soc Trang", "Bac Lieu", "Ca Mau"};

int Real_ID[N] = {
    35, 47, 25, 26, 13, 3, 53, 2, 5, 29, 52, 21, 59, 61, 23, 22, 38, 36, 62, 42,
    28, 40, 33, 17, 50, 54, 39, 24, 44, 48, 55, 14, 45, 32, 46, 20, 10, 15, 43, 30,
    41, 34, 16, 8, 9, 18, 7, 51, 57, 1, 37, 56, 19, 6, 58, 60, 12, 0, 31, 27,
    49, 4, 11
};

vector<int> Edge[N] = {
    {1, 7, 6, 5, 4},             // 0 - Lang Son
    {3, 2, 7, 0},                // 1 - Quang Ninh
    {1, 3, 7, 8, 9, 10},             // 2 - Hai Duong
    {1, 2, 10},             // 3 - Hai Phong
    {0, 5, 12, 11},                   // 4 - Cao Bang
    {0, 6, 12,4},      // 5 - Bac Kan
    {0,7,14,13,12,5}, // 6 - Thai Nguyen
    {0,1,2,8,14,6},            // 7 - Bac Giang
    {7,2,9,14},       // 8 - Bac Ninh
    {8,2,10,15,14},    // 9 - Hung Yen
    {3,2,9,15,16},    // 10 - Thai Binh
    {4,12,17},          // 11 - Ha Giang
    {4,5,6,13,19,18,11},    // 12 - Tuyen Quang
    {6,14,19,12},  // 13 - Vinh Phuc
    {6,7,8,9,15,20,19,13},          // 14 - Ha Noi
    {9,10,16,21,20,14},  // 15 - Ha Nam
    {10,15,21}, // 16 - Nam Dinh
    {11,18,22},         // 17 - Lao Cai
    {12,19,24,22},     // 18 - Yen Bai
    {12,13,14,20,24,18}, // 19 - Phu Tho
    {14,15,21,25,24,19},         // 20 - Hoa Binh
    {15,16,20,25},             // 21 - Ninh Binh
    {17,18,24},     // 22 - Lai Chau
    {24},             // 23 - Dien Bien
    {23,22,18,19,20,25}, // 24 - Son La
    {21,20,24,26},          // 25 - Thanh Hoa
    {25,27},                    // 26 - Nghe An
    {26, 28},                // 27 - Ha Tinh
    {27, 29},                // 28 - Quang Binh
    {28, 30},                // 29 - Quang Tri
    {29, 31, 32},            // 30 - Hue
    {30, 32},                // 31 - Da Nang
    {30, 31, 33, 34},            // 32 - Quang Nam
    {32, 35},            // 33 - Kom Tum
    {32, 36},        // 34 - Quang Ngai
    {33, 36, 37},    // 35 - Gia Lai
    {34, 35, 38},            // 36 - Binh Dinh
    {35, 38, 41, 42},    // 37 - Dak Lak
    {36, 37, 39},        // 38 - Phu Yen
    {38, 40, 41},        // 39 - Khanh Hoa
    {39, 41, 44},            // 40 - Ninh Thuan
    {37, 39, 40, 42, 44, 43, 45},    // 41 - Lam Dong
    {37, 41, 43},            // 42 - Dak Nong
    {41, 42, 45, 46, 47},    // 43 - Binh Phuoc
    {40, 41, 45, 49},    // 44 - Binh Thuan
    {44,41,43,49,48,46},        // 45 - Dong Nai
    {43,47,48,45}, // 46 - Binh Duong
    {43, 46, 48, 50},        // 47 - Tay Ninh
    {47,46,45,49,50},        // 48 - Sai Gon
    {44, 45, 48},    // 49 - BRVT
    {47, 48, 51, 52},            // 50 - Long An
    {53, 55, 52, 50},        // 51 - Tien Giang
    {50, 51, 55, 56, 57},        // 52 - Dong Thap
    {51, 54, 55},    // 53 - Ben Tre
    {53, 55, 60},            // 54 - Tra Vinh
    {53, 51, 52, 54, 56, 59, 60},            // 55 - Vinh Long
    {52, 55, 57, 58, 59}, // 56 - Can Tho
    {52, 56, 58},    // 57 - An Giang
    {56, 57, 59, 61, 62},            // 58 - Kien Giang
    {55, 56, 60, 61, 58},    // 59 - Hau Giang
    {54, 55, 59, 61},    // 60 - Soc Trang
    {60, 59, 58, 62},        // 61 - Bac Lieu
    {58, 61}                 // 62 - Ca Mau
};
/*
        Khác với danh sách kề đã liệt kê ở câu 3: Một số cặp đỉnh sẽ không được coi
    không kề nhauvì đường giáp ranh giữa hai tỉnh khá nhỏ.
            Quãng Ngãi - Gia Lai
            TP HCM - Tiền Giang
        Đường đi hiểm trở
            //    if (IsAppear(33,ds) && IsAppear(34,ds)) return false;
            //    if (IsAppear(22,ds) && IsAppear(23,ds)) return false;
            //    if (IsAppear(18,ds) && IsAppear(11,ds)) return false;
            //    if (IsAppear(35,ds) && IsAppear(38,ds)) return false;
            //    if (IsAppear(37,ds) && IsAppear(39,ds)) return false;
*/

int Area[N] = {
    8310,   // Lang Son
    6208,   // Quang Ninh
    1668,   // Hai Duong
    1527,   // Hai Phong
    6700,   // Cao Bang
    4860,   // Bac Kan
    3522,   // Thai Nguyen
    3896,   // Bac Giang
    823,    // Bac Ninh
    930,    // Hung Yen
    1585,   // Thai Binh
    7928,   // Ha Giang
    5868,   // Tuyen Quang
    1236,   // Vinh Phuc
    3360,   // Ha Noi
    862,    // Ha Nam
    1669,   // Nam Dinh
    6364,   // Lao Cai
    6893,   // Yen Bai
    3535,   // Phu Tho
    4590,   // Hoa Binh
    1412,   // Ninh Binh
    9069,   // Lai Chau
    9540,   // Dien Bien
    14110,  // Son La
    11115,  // Thanh Hoa
    16486,  // Nghe An
    5994,   // Ha Tinh
    7999,   // Quang Binh
    4701,   // Quang Tri
    4947,   // Hue
    1285,   // Da Nang
    10575,  // Quang Nam
    9677,   // Kom Tum
    5155,   // Quang Ngai
    15510,  // Gia Lai
    6066,   // Binh Dinh
    13070,  // Dak Lak
    5026,   // Phu Yen
    5200,   // Khanh Hoa
    3356,   // Ninh Thuan
    9781,   // Lam Dong
    6509,   // Dak Nong
    6874,   // Binh Phuoc
    7943,   // Binh Thuan
    5864,   // Dong Nai
    2695,   // Binh Duong
    4042,   // Tay Ninh
    2095,   // Sai Gon
    1983,   // BRVT
    4495,   // Long An
    2556,   // Tien Giang
    3382,   // Dong Thap
    2380,   // Ben Tre
    2391,   // Tra Vinh
    1526,   // Vinh Long
    1440,   // Can Tho
    3537,   // An Giang
    6353,   // Kien Giang
    1622,   // Hau Giang
    3298,   // Soc Trang
    2668,   // Bac Lieu
    5275    // Ca Mau
};

int Population[N] = {
    813978,     // Lang Son
    1393702,    // Quang Ninh
    1971326,    // Hai Duong
    2121841,    // Hai Phong
    555809,     // Cao Bang
    328609,     // Bac Kan
    1361474,    // Thai Nguyen
    1950615,    // Bac Giang
    1543529,    // Bac Ninh
    1313798,    // Hung Yen
    1888184,    // Thai Binh
    908263,     // Ha Giang
    820054,     // Tuyen Quang
    1221803,    // Vinh Phuc
    8685607,    // Ha Noi
    892755,     // Ha Nam
    1892427,    // Nam Dinh
    787066,     // Lao Cai
    863338,     // Yen Bai
    1540608,    // Phu Tho
    892373,     // Hoa Binh
    1027030,    // Ninh Binh
    494626,     // Lai Chau
    653422,     // Dien Bien
    1327430,    // Son La
    3760650,    // Thanh Hoa
    3470988,    // Nghe An
    1329365,    // Ha Tinh
    924169,     // Quang Binh
    658619,     // Quang Tri
    1177624,    // Hue
    1269070,    // Da Nang
    1539468,    // Quang Nam
    598201,     // Kom Tum
    1256952,    // Quang Ngai
    1630311,    // Gia Lai
    1515422,    // Binh Dinh
    1944821,    // Dak Lak
    883298,     // Phu Yen
    1267443,    // Khanh Hoa
    609820,     // Ninh Thuan
    1361129,    // Lam Dong
    692896,     // Dak Nong
    1060448,    // Binh Phuoc
    1266240,    // Binh Thuan
    3341716,    // Dong Nai
    2858815,    // Binh Duong
    1201736,    // Tay Ninh
    9521886,    // Sai Gon (TP. HCM)
    1192863,    // BRVT
    1753041,    // Long An
    1795251,    // Tien Giang
    1600963,    // Dong Thap
    1305281,    // Ben Tre
    1022887,    // Tra Vinh
    1035362,    // Vinh Long
    1268514,    // Can Tho
    1911002,    // An Giang
    1763826,    // Kien Giang
    728924,     // Hau Giang
    1203705,    // Soc Trang
    929439,     // Bac Lieu
    1210843     // Ca Mau
};

int GRDP[N] = {
    50,  // Lang Son
    348, // Quang Ninh
    212, // Hai Duong
    446, // Hai Phong
    25,  // Cao Bang
    19,  // Bac Kan
    167, // Thai Nguyen
    207, // Bac Giang
    232, // Bac Ninh
    160, // Hung Yen
    71,  // Thai Binh
    36,  // Ha Giang
    50,  // Tuyen Quang
    173, // Vinh Phuc
    1430, // Ha Noi
    56,  // Ha Nam
    113, // Nam Dinh
    77,  // Lao Cai
    49,  // Yen Bai
    107, // Phu Tho
    72,  // Hoa Binh
    99,  // Ninh Binh
    31,  // Lai Chau
    32,  // Dien Bien
    77,  // Son La
    319, // Thanh Hoa
    217, // Nghe An
    113, // Ha Tinh
    60,  // Quang Binh
    54,  // Quang Tri
    80,  // Hue
    151, // Da Nang
    129, // Quang Nam
    41,  // Kom Tum
    133, // Quang Ngai
    111, // Gia Lai
    131, // Binh Dinh
    141, // Dak Lak
    63,  // Phu Yen
    129, // Khanh Hoa
    60,  // Ninh Thuan
    13,  // Lam Dong
    56,  // Dak Nong
    115, // Binh Phuoc
    121, // Binh Thuan
    494, // Dong Nai
    520, // Binh Duong
    124, // Tay Ninh
    1778, // Sai Gon (TP. Ho Chi Minh)
    417, // BRVT
    189, // Long An
    137, // Tien Giang
    124, // Dong Thap
    74,  // Ben Tre
    97,  // Tra Vinh
    84,  // Vinh Long
    133, // Can Tho
    127, // An Giang
    144, // Kien Giang
    68,  // Hau Giang
    80,  // Soc Trang
    66,  // Bac Lieu
    88   // Ca Mau
};

int trace[N][MaxM][MASK(Log)];

int f[N][MaxM][MASK(Log)];

int sumGRDP = 0;

void prepare() {
    for (int i=0;i<N;i++) {
        for (int j=0;j<MASK(Log);j++) {
            for (int m=0;m<MaxM;m++) {
                f[i][m][j] = INF; // Đặt tất cả giá trị về dương vô cùng vì hàm mục tiêu là MIN
                trace[i][m][j] = 0;
            }
        }
    }
    f[0][0][0] = 0;
}

bool IsAppear(int u,vector<int> & ds)  {
    // Kiểm tra đỉnh thứ u có nằm trong cụm tỉnh [ds] không
    for (int x : ds) {
        if (x == u) return true;
    }
    return false;
}

bool Check(vector<int> ds) {
//Kiểm tra khả năng sáp nhập của cụm tỉnh [ds]

    // Cao Bang không sáp nhập với tỉnh nào khác
    if (IsAppear(4,ds)) return ds.size() == 1;

    // Hà Nội sáp nhập với nhiều nhất 1 tỉnh
    if (IsAppear(14,ds)) return ds.size() <= 2;

    // Các cặp tỉnh không thể sáp nhập vì vấn đề về giao thông
//    if (IsAppear(33,ds) && IsAppear(34,ds)) return false;
//    if (IsAppear(22,ds) && IsAppear(23,ds)) return false;
//    if (IsAppear(18,ds) && IsAppear(11,ds)) return false;
//    if (IsAppear(35,ds) && IsAppear(38,ds)) return false;
//    if (IsAppear(37,ds) && IsAppear(39,ds)) return false;

    // Xét các điều kiện về diện tích và dân số
    int Sum_Area = 0;
    long long Sum_Population = 0;
    for (int x : ds) {
        Sum_Area += Area[x];
        Sum_Population += Population[x];
    }
    return Sum_Area >= Min_Area && Sum_Population >= Min_Population && Sum_Area <= Max_Area;
}

int SumGRDP(vector<int> & ds) {
    int sum = 0;
    for (int x : ds) {
        sum += GRDP[x];
    }
    return sum;
}

void Push(int pos,int m,int OldMask,vector<int> ds) {
// Cập nhật giá trị tối ưu và lưu vết cho trạng thái mới khi sáp nhập cụm tỉnh [ds]
    if (!Check(ds)) return;
    for (int x : ds) if (BIT(OldMask,x - pos)) return;
    int NewMask = OldMask;
    for (int x : ds) NewMask |= MASK(x - pos);
    if (minimize(f[pos][m+1][NewMask],f[pos][m][OldMask] + SQR(SumGRDP(ds)))) {
        trace[pos][m+1][NewMask] = 0;
        for (int x : ds) trace[pos][m+1][NewMask] |= MASK(x-pos);
    }
}

void Update_To_Next_Province(int pos) {
//Cập nhật cửa sổ để xét tỉnh tiếp theo
    for (int m=0;m<MaxM;m++) {
        for (int mask=0;mask<MASK(Log);mask++) {
            if (BIT(mask,0) && f[pos][m][mask] < INF) minimize(f[pos+1][m][mask>>1],f[pos][m][mask]);
        }
    }
}

void sol() {
    // Quy hoạch động bitmask, duyệt theo ý tưởng đã nêu
    for (int x=0;x<N;x++) {
        for (int m=0;m<MaxM;m++) {
            for (int mask=0;mask<MASK(Log);mask++) {
                if (BIT(mask,0) || f[x][m][mask] >= INF) continue;
                Push(x,m,mask,{x}); // tỉnh x không sáp nhập
                for (int y:Edge[x]) {
                    if (y <= x) continue;
                    Push(x,m,mask,{x,y}); // tỉnh x sáp nhập với 1 tỉnh

                    // Tỉnh x sáp nhập với 2 tỉnh
                    for (int z:Edge[y]) {
                        if (z <= x) continue;
                        Push(x,m,mask,{x,y,z});
                    }
                    for (int z:Edge[x]) {
                        if (z <= x || z == y) continue;
                        Push(x,m,mask,{x,y,z});
                    }
                }
            }
        }
        if (x == N - 1) continue;
        // Cập nhật cửa sổ tiếp theo
        Update_To_Next_Province(x);
    }
    // Đặt S = sumGRDP^2
    for (int i=0;i<N;i++) sumGRDP += GRDP[i];
    int S = SQR(sumGRDP);

    int M = 0; // Lượng tỉnh sao cho phương án tối ưu nhất
    for (int i=0;i<MaxM;i++) {
        if (f[N-1][i][1] >= INF) continue; // Nếu trường hợp số tỉnh là i không có phương án thì bỏ qua
        if (M == 0) M = i; // Tạo cho M giá trị ban đầu

        // Lấy sổ lượng tối ưu cho hàm mục tiêu giữa M và i
        if (1LL*(i*f[N-1][i][1]-S)*SQR(M) < 1LL*(M*f[N-1][M][1]-S)*SQR(i)) {
            M = i;
        }
    }

    // Truy vết
    int pos = N-1;
    int mask = 1;
    while (M != 0) {
        if (trace[pos][M][mask] == 0) {
            pos--;
            mask = mask << 1 | 1;
        }
        else {
            int tmpp = trace[pos][M][mask];
            for (int i=0;i<Log;i++) {
                if (BIT(tmpp,i)) {
                    cout << Province[i+pos] << ' ';
                    mask ^= MASK(i);
                }
            }
            M--;
            cout << '\n';
        }
    }
}

int main() {
//    freopen("YeuCau_6_MoTa.out","w",stdout);
    prepare();
    sol();
}
