Xem xét quá trình:
Lấy một số nguyên không âm N.
ví dụ27
.Chia nó thành các số nguyên
N - floor(N/2)
vàfloor(N/2)
(một nửa 'lớn hơn' và 'nhỏ hơn') và viết chúng theo thứ tự đó.
ví dụ27
trở thành14 13
.Xóa không gian để nối các số nguyên thành một số nguyên mới, lớn hơn nhiều.
ví dụ14 13
trở thành1413
.Lặp lại các bước 2 và 3 một số lần mong muốn.
ví dụ:1413
→707 706
→707706
→353853 353853
→353853353853
→ ...
Thử thách này là về việc thực hiện chính xác điều này, nhưng không phải lúc nào cũng ở cơ sở 10.
Thử thách
Viết chương trình có ba số B, N và S:
B là một số nguyên từ 2 đến 10 là cơ sở của N (nhị phân đến thập phân).
N là số nguyên không âm để áp dụng quy trình chia tách lại. Để làm cho đầu vào của người dùng dễ dàng hơn, nó được cung cấp dưới dạng một chuỗi trong cơ sở B, không phải là một số nguyên.
S là một số nguyên không âm là số lần lặp lại quá trình chia tách lại.
Đầu ra của chương trình là biểu diễn chuỗi của N trong cơ sở B sau các thủ tục chia tách S.
Khi S là 0
, không có sự phân tách nào được thực hiện, vì vậy đầu ra luôn là N.
Khi N là 0
, tất cả các phần tách có dạng 0 0
và giảm xuống 0
một lần nữa, vì vậy đầu ra luôn luôn 0
.
Ví dụ
B = 10, N = 27, S = 1
→1413
B = 10, N = 27, S = 2
→707706
B = 9, N = 27, S = 1
→1413
B = 9, N = 27, S = 2
→652651
B = anything, N = anything, S = 0
→N
B = anything, N = 0, S = anything
→0
Bảng cho tất cả B với N = 1
for S = 0
to 7
:
B S=0 S=1 S=2 S=3 S=4 S=5 S=6 S=7
2 1 10 11 101 1110 111111 10000011111 10000100001000001111
3 1 10 21 1110 202201 101101101100 1201201201212012012011 212100212102121002121212100212102121002120
4 1 10 22 1111 223222 111311111311 2232222232322322222322 11131111131311311111311113111113131131111131
5 1 10 32 1413 432431 213441213440 104220331443104220331442 2433241322130211014044424332413221302110140443
6 1 10 33 1514 535535 245550245545 122553122553122553122552 4125434125434125434125441254341254341254341254
7 1 10 43 2221 11111110 40404044040403 2020202202020220202022020201 10101011010101101010110101011010101101010110101011010100
8 1 10 44 2222 11111111 44444454444444 2222222622222222222226222222 11111113111111111111131111111111111311111111111113111111
9 1 10 54 2726 13581357 62851746285173 3142536758708231425367587081 15212633743485606571782880411521263374348560657178288040
10 1 10 55 2827 14141413 70707077070706 3535353853535335353538535353 17676769267676676767692676771767676926767667676769267676
Bảng cho tất cả B với N ngẫu nhiên cho S = 0
to 3
:
B S=0 S=1 S=2 S=3
2 11011 11101101 11101111110110 11101111110111110111111011
3 2210 11021101 20102012010200 1001212100121210012121001211
4 1113 230223 112112112111 2302302302323023023022
5 101 2323 11341134 31430423143042
6 120 4040 20202020 1010101010101010
7 134 5252 24612461 1230456412304564
8 22 1111 445444 222622222622
9 4 22 1111 505505
10 92 4646 23232323 1161616211616161
Chi tiết
- Lấy đầu vào thông qua stdin hoặc dòng lệnh. Đầu ra cho thiết bị xuất chuẩn.
- Thay vì một chương trình, bạn có thể viết một hàm lấy B, N và S và in kết quả bình thường hoặc trả về nó (dưới dạng một chuỗi).
- B, N và S có thể được thực hiện theo thứ tự bất kỳ.
- Tất cả các đầu vào tạo ra đầu ra có giá trị thập phân dưới 2 32 sẽ hoạt động.
- N được biểu diễn theo cách thông thường. tức là chữ số có nghĩa đầu tiên và không có số 0 đứng đầu, ngoại trừ số 0 được viết
0
. (Xuất ra00
thay vì0
không hợp lệ.) - Mã ngắn nhất tính bằng byte thắng.
Nếu bạn thích những thách thức của tôi, hãy xem xét đưa ra Block Bot Bot Flocks! một số tình yêu :)