#include <bits/stdc++.h>
using namespace std;
#define MASK(i) (1LL<<(i)) // Trả về giá trị 2^i
#define BIT(n,i) ((n>>i)&1) // Kiểm tra Bit thứ i của trạng thái n
const int INF = 1e9+7; // Giá trị dương vô cùng
// Kiểm tra và Cập nhật giá trị nhỏ hơn cho x từ y
template<class _, class __>
bool minimize(_ &x, const __ y){
if(x > y){
x = y;
return true;
} else return false;
}
// Kiểm tra và Cập nhật giá trị lớn hơn cho x từ y
template<class _, class __>
bool maximize(_ &x, const __ y){
if(x < y){
x = y;
return true;
} else return false;
}
const int N = 63; // Số lượng tỉnh ở Việt Nam
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; // Dân số thấp nhất của một tỉnh sau khi sáp nhập
const int Min_Area = 6500; // Diện tích nhỏ nhất của một tỉnh sau khi sáp nhập
// Tên các tỉnh theo thứ tự chúng tôi sắp xếp
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"};
// Số thứ tự do đề bài ra
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
};
// Danh sách các tỉnh lân cận của từng tỉnh
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,11,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,18,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
{11,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,25,23}, // 22 - Lai Chau
{22,24}, // 23 - Dien Bien
{23,22,18,19,20,25}, // 24 - Son La
{21,20,24}, // 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, 34, 35}, // 33 - Kom Tum
{32, 33, 35, 36}, // 34 - Quang Ngai
{33, 34, 36, 37, 38}, // 35 - Gia Lai
{34, 35, 38}, // 36 - Binh Dinh
{35, 38, 39, 41, 42}, // 37 - Dak Lak
{35, 36, 37, 39}, // 38 - Phu Yen
{37, 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,51}, // 48 - Sai Gon
{44, 45, 48}, // 49 - BRVT
{47, 48, 51, 52}, // 50 - Long An
{53, 55, 52, 50, 48}, // 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
};
// Diện tích các tỉnh
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
};
// Dân số các tỉnh
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 trace[N][MASK(Log)]; // Mảng truy vết
int f[N][MASK(Log)]; // Hàm mục tiêu
void prepare() {
// Bài toán cơ sở
for (int i=0;i<N;i++) {
for (int j=0;j<MASK(Log);j++) {
f[i][j] = INF;
// Dương vô cùng nếu hàm mục tiêu cần tìm MIN
// Âm vô cùng nếu hàm mục tiêu cần tìm MAX
trace[i][j] = 0;
}
}
f[0][0] = 0; // Giá trị của trạng trái 0000...0
}
bool Check_Population_Area(vector<int> ds) {
// Kiểm tra điều kiện về dân số và diện tích của cụm tỉnh mới [ds]
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;
}
void Push(int pos,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]
// Xét dân số và diện tích của cụm tỉnh [ds]
if (!Check_Population_Area(ds)) return;
// Xét các tỉnh trong [ds] đã được sáp nhập hay chưa
for (int x : ds) if (BIT(OldMask,x - pos)) return;
// Tạo ra trạng thái mới từ trạng thái cũ sau khi sáp nhập cụm tỉnh [ds]
int NewMask = OldMask;
for (int x : ds) NewMask |= MASK(x - pos);
// Cập nhập giá trị tối ưu cho trạng thái mới
if (minimize(f[pos][NewMask],f[pos][OldMask] + (ds.size() == 3))) {
// Lưu vết cho trạng thái mới
trace[pos][NewMask] = 0;
for (int x : ds) trace[pos][NewMask] |= MASK(x - pos);
}
}
void Update_To_Next_Province(int pos) {
// Cập nhật cửa sổ để xét đỉnh tiếp theo
for (int mask=0;mask < MASK(Log);mask++) {
if (BIT(mask,0)) minimize(f[pos+1][mask>>1],f[pos][mask]);
// minimize nếu hàm mục tiêu là MIN
// maximize nếu hàm mục tiêu là MAX
}
}
void sol() {
// Quy hoạch động bitmask
for (int x=0;x<N;x++) {
for (int mask=0;mask<MASK(Log);mask++) {
if (BIT(mask,0) == 0 && f[x][mask] < INF) {
Push(x,mask,{x}); // Xét tỉnh mới chỉ gồm một tỉnh x
for (int y : Edge[x]) {
if (y <= x) continue;
Push(x,mask,{x,y}); // Xét tỉnh mới gồm 2 tỉnh x và một đỉnh kề x
for (int z:Edge[y]) {
if (z <= x) continue;
Push(x,mask,{x,y,z}); /*Xét cụm tỉnh mới gồm 3 tỉnh :
tỉnh x
tỉnh y giáp với tỉnh x
tỉnh z giáp với tỉnh y
*/
}
for (int z:Edge[x]) {
if (z <= x || z == y) continue;
Push(x,mask,{x,y,z}); /*Xét cụm tỉnh mới gồm 3 tỉnh:
tỉnh x
tỉnh y giáp với tỉnh x
tỉnh z giáp với tỉnh x
*/
}
}
}
}
if (x == N - 1) continue;
// cập nhật cửa sổ để xét đỉnh tiếp theo
Update_To_Next_Province(x);
}
// Truy vết
int pos = N-1;
int mask = 1;
while (pos != 0 || mask != 0) {
if (trace[pos][mask] == 0) {
pos--;
mask = mask << 1 | 1;
}
else {
int tmp = trace[pos][mask];
for (int i=0;i<Log;i++) {
if (BIT(tmp,i)) {
cout << Real_ID[pos+i] << ' ';
mask ^= MASK(i);
}
}
cout << '\n';
}
}
}
int main() {
// freopen("ketqua.out","w",stdout);
prepare();
sol();
}
#include <bits/stdc++.h>
using namespace std;

#define MASK(i) (1LL<<(i)) // Trả về giá trị 2^i
#define BIT(n,i) ((n>>i)&1) // Kiểm tra Bit thứ i của trạng thái n

const int INF = 1e9+7; // Giá trị dương vô cùng

// Kiểm tra và Cập nhật giá trị nhỏ hơn cho x từ y
template<class _, class __>
    bool minimize(_ &x, const __ y){
        if(x > y){
            x = y;
            return true;
        } else return false;
    }

// Kiểm tra và Cập nhật giá trị lớn hơn cho x từ y
template<class _, class __>
    bool maximize(_ &x, const __ y){
        if(x < y){
            x = y;
            return true;
        } else return false;
    }

const int N = 63; // Số lượng tỉnh ở Việt Nam
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; // Dân số thấp nhất của một tỉnh sau khi sáp nhập
const int Min_Area = 6500; // Diện tích nhỏ nhất của một tỉnh sau khi sáp nhập

// Tên các tỉnh theo thứ tự chúng tôi sắp xếp
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"};

// Số thứ tự do đề bài ra
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
};

// Danh sách các tỉnh lân cận của từng tỉnh
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,11,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,18,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
    {11,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,25,23},     // 22 - Lai Chau
    {22,24},             // 23 - Dien Bien
    {23,22,18,19,20,25}, // 24 - Son La
    {21,20,24},          // 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, 34, 35},            // 33 - Kom Tum
    {32, 33, 35, 36},        // 34 - Quang Ngai
    {33, 34, 36, 37, 38},    // 35 - Gia Lai
    {34, 35, 38},            // 36 - Binh Dinh
    {35, 38, 39, 41, 42},    // 37 - Dak Lak
    {35, 36, 37, 39},        // 38 - Phu Yen
    {37, 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,51},        // 48 - Sai Gon
    {44, 45, 48},    // 49 - BRVT
    {47, 48, 51, 52},            // 50 - Long An
    {53, 55, 52, 50, 48},        // 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
};

// Diện tích các tỉnh
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
};

// Dân số các tỉnh
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 trace[N][MASK(Log)]; // Mảng truy vết

int f[N][MASK(Log)]; // Hàm mục tiêu

void prepare() {
    // Bài toán cơ sở
    for (int i=0;i<N;i++) {
        for (int j=0;j<MASK(Log);j++) {
            f[i][j] = INF;
            // Dương vô cùng nếu hàm mục tiêu cần tìm MIN
            // Âm vô cùng nếu hàm mục tiêu cần tìm MAX
            trace[i][j] = 0;
        }
    }
    f[0][0] = 0; // Giá trị của trạng trái 0000...0
}

bool Check_Population_Area(vector<int> ds) {
    // Kiểm tra điều kiện về dân số và diện tích của cụm tỉnh mới [ds]
    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;
}

void Push(int pos,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]

    // Xét dân số và diện tích của cụm tỉnh [ds]
    if (!Check_Population_Area(ds)) return;

    // Xét các tỉnh trong [ds] đã được sáp nhập hay chưa
    for (int x : ds) if (BIT(OldMask,x - pos)) return;

    // Tạo ra trạng thái mới từ trạng thái cũ sau khi sáp nhập cụm tỉnh [ds]
    int NewMask = OldMask;
    for (int x : ds) NewMask |= MASK(x - pos);

    // Cập nhập giá trị tối ưu cho trạng thái mới
    if (minimize(f[pos][NewMask],f[pos][OldMask] + (ds.size() == 3))) {
        // Lưu vết cho trạng thái mới
        trace[pos][NewMask] = 0;
        for (int x : ds) trace[pos][NewMask] |= MASK(x - pos);
    }
}

void Update_To_Next_Province(int pos) {
    // Cập nhật cửa sổ để xét đỉnh tiếp theo
    for (int mask=0;mask < MASK(Log);mask++) {
        if (BIT(mask,0)) minimize(f[pos+1][mask>>1],f[pos][mask]);
        // minimize nếu hàm mục tiêu là MIN
        // maximize nếu hàm mục tiêu là MAX
    }
}

void sol() {
    // Quy hoạch động bitmask
    for (int x=0;x<N;x++) {
        for (int mask=0;mask<MASK(Log);mask++) {
            if (BIT(mask,0) == 0 && f[x][mask] < INF) {
                Push(x,mask,{x}); // Xét tỉnh mới chỉ gồm một tỉnh x
                for (int y : Edge[x]) {
                    if (y <= x) continue;
                    Push(x,mask,{x,y}); // Xét tỉnh mới gồm 2 tỉnh x và một đỉnh kề x
                    for (int z:Edge[y]) {
                        if (z <= x) continue;
                        Push(x,mask,{x,y,z});   /*Xét cụm tỉnh mới gồm 3 tỉnh :
                                                    tỉnh x
                                                    tỉnh y giáp với tỉnh x
                                                    tỉnh z giáp với tỉnh y
                                                */
                    }
                    for (int z:Edge[x]) {
                        if (z <= x || z == y) continue;
                        Push(x,mask,{x,y,z}); /*Xét cụm tỉnh mới gồm 3 tỉnh:
                                                    tỉnh x
                                                    tỉnh y giáp với tỉnh x
                                                    tỉnh z giáp với tỉnh x
                                                */
                    }
                }
            }
        }
        if (x == N - 1) continue;
        // cập nhật cửa sổ để xét đỉnh tiếp theo
        Update_To_Next_Province(x);
    }
    // Truy vết
    int pos = N-1;
    int mask = 1;
    while (pos != 0 || mask != 0) {
        if (trace[pos][mask] == 0) {
            pos--;
            mask = mask << 1 | 1;
        }
        else {
            int tmp = trace[pos][mask];
            for (int i=0;i<Log;i++) {
                if (BIT(tmp,i)) {
                    cout << Real_ID[pos+i] << ' ';
                    mask ^= MASK(i);
                }
            }
            cout << '\n';
        }
    }
}

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