Problem
Gooli is a huge company that owns B buildings in a hilly area. The buildings are numbered from 1 to B.
The CEO wants to build a set of slides between buildings that she can use to travel from her office in building 1 to her favorite cafe in building B. Slides, of course, are one-way only, but the buildings are tall and have elevators, so a slide can start in any building and end in any other building, and can go in either direction. Specifically, for any two buildings x and y, you can build either zero or one slides from x to y, and you can build either zero or one slides from y to x. The exception is that no slides are allowed to originate in building B, since once the CEO reaches that building, there is no need for her to do any more sliding.
In honor of Gooli becoming exactly M milliseconds old, the design must ensure that the CEO has exactly M different ways to travel from building 1 to building B using the new slides. A way is a sequence of buildings that starts with building 1, ends with building B, and has the property that for each pair of consecutive buildings x and y in the sequence, a slide exists from x to y. Note that the CEO is not requiring that any building be reachable from any other building via slides.
Can you come up with any set of one or more slides that satisfies the CEO’s requirements, or determine that it is impossible?
Input and Output
Input
The first line of the input gives the number of test cases, T. T lines follow; each consists of one line with two integers B and M, as described above.
Output
For each test case, output one line containing Case #x: y, where x is the test case number (starting from 1) and y is the word POSSIBLE or IMPOSSIBLE, depending on whether the CEO’s requirements can be fulfilled or not. If it is possible, output an additional B lines containing B characters each, representing a matrix describing a valid way to build slides according to the requirements. The j-th character of the i-th of these lines (with both i and j counting starting from 1) should be 1 if a slide should be built going from building i to building j, and 0 otherwise. The i-th character of the i-th line should always be 0, and every character of the last line should be 0.
If multiple solutions are possible, you may output any of them.
Limits
1 ≤ T ≤ 100.
Small dataset
2 ≤ B ≤ 6.
1 ≤ M ≤ 20.
Large dataset
2 ≤ B ≤ 50.
1 ≤ M ≤ 1018.
Sample
Input
3
5 4
2 1
4 20
Output
Case #1: POSSIBLE
01001
00110
00001
00101
00000
Case #2: POSSIBLE
01
00
Case #3: IMPOSSIBLE
The sample outputs show one possible way to fulfill the specifications for each case. Other valid answers may exist.
Here is an illustration of the sample answer for Case #1:
The four ways to get from building 1 to building 5 are:
1 to 5 1 to 2 to 3 to 5 1 to 2 to 4 to 5 1 to 2 to 4 to 3 to 5
In Case #3, building slides from 1 to 2, 2 to 3, 3 to 1, and 1 to 4 would create infinitely many ways for the CEO to reach building 4 (she could go directly to 4, or go around the loop once and then go to 4, or go around the loop twice…), but the CEO requested exactly 20 ways.
Codes
#include <iostream>
#include <algorithm>
using namespace std;
int main() {
freopen("C:\\Users\\Administrator\\Downloads\\B-small-practice.in","r",stdin);
freopen("C:\\Users\\Administrator\\Downloads\\B-small-attempt0.out","w",stdout);
int num, B;
long long M;
cin >> num;
for (int i = 0; i < num; i++) {
cout << "Case #" << i + 1 << ": ";
cin >> B >> M;
if (M > (1LL << (B - 2))) cout << "IMPOSSIBLE" << endl;
else {
cout << "POSSIBLE" << endl;
for (int i = 0; i< B; i++) {
for (int j = 0; j < B; j++) {
if (i < j && j < B - 1) cout << "1";
else if (j == B - 1 && (i == 0 || (M - 1) & 1LL<<(i - 1))) cout << "1";
else cout << "0";
}
cout << endl;
}
}
}
return 0;
}