양의 정수 n 을 입력으로 사용 하고 다음과 같은 순서로 n 비트를 사용하여 만들 수있는 10 진수를 출력합니다 (일부) .
먼저 하나만으로 생성 할 수있는 모든 숫자를 나열 1
하고 나머지 0
는 이진 표현 (정렬)으로 나열한 다음 두 개의 연속 1
, 나머지 0
는 3 연속 으로 생성 할 수있는 모든 숫자를 나열 하십시오 1
.
n = 4의 모습을 봅시다 :
0001 - 1
0010 - 2
0100 - 4
1000 - 8
0011 - 3
0110 - 6
1100 - 12
0111 - 7
1110 - 14
1111 - 15
따라서 n = 4 의 출력 은 1, 2, 4, 8, 3, 6, 12, 7, 14, 15입니다 (선택적 출력 형식).
테스트 사례 :
n = 1
1
n = 2
1 2 3
n = 3
1, 2, 4, 3, 6, 7
n = 8
1, 2, 4, 8, 16, 32, 64, 128, 3, 6, 12, 24, 48, 96, 192, 7, 14, 28, 56, 112, 224, 15, 30, 60, 120, 240, 31, 62, 124, 248, 63, 126, 252, 127, 254, 255
n = 17
1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536, 3, 6, 12, 24, 48, 96, 192, 384, 768, 1536, 3072, 6144, 12288, 24576, 49152, 98304, 7, 14, 28, 56, 112, 224, 448, 896, 1792, 3584, 7168, 14336, 28672, 57344, 114688, 15, 30, 60, 120, 240, 480, 960, 1920, 3840, 7680, 15360, 30720, 61440, 122880, 31, 62, 124, 248, 496, 992, 1984, 3968, 7936, 15872, 31744, 63488, 126976, 63, 126, 252, 504, 1008, 2016, 4032, 8064, 16128, 32256, 64512, 129024, 127, 254, 508, 1016, 2032, 4064, 8128, 16256, 32512, 65024, 130048, 255, 510, 1020, 2040, 4080, 8160, 16320, 32640, 65280, 130560, 511, 1022, 2044, 4088, 8176, 16352, 32704, 65408, 130816, 1023, 2046, 4092, 8184, 16368, 32736, 65472, 130944, 2047, 4094, 8188, 16376, 32752, 65504, 131008, 4095, 8190, 16380, 32760, 65520, 131040, 8191, 16382, 32764, 65528, 131056,16383, 32766, 65532, 131064, 32767, 65534, 131068, 65535, 131070, 131071
이것은 code-golf 이므로 각 언어 에서 가장 짧은 코드가 승리합니다!
"일반 언어"의 솔루션에 대해서도 좋은 설명을 적극 권장합니다 !