Ruby (1.9+)
Vì đây là một cuộc thi nổi tiếng, chúng ta hãy cố gắng không sử dụng BẤT K of nhân vật nào trong 'Xin chào thế giới!' trong khi vẫn sử dụng các ký tự khác chỉ tối đa hai lần:
puts("S\107VsbG8gV29ybGQhCg".unpack(?m))
Đó là 40 ký tự btw.
Bash
Và cái này sử dụng phép thuật unicode.
Ghi chú:
- Trong khi các ký tự gốc xuất hiện ở nơi khác (không giống như ví dụ ruby), chuỗi in chỉ chứa các ký tự không phải mã ascii.
- Hai trong số ba khoảng trắng thực sự là các tab, vì vậy không có ký tự utf-8 nào xuất hiện hơn 2 lần
- Vì nhị phân, một số octet xuất hiện hơn 2 lần, hy vọng điều đó không trái với quy tắc. Tôi đang cố gắng giải quyết chúng mặc dù.
Mã số:
echo '𝓗𝐞𝑙𝒍𝓸 𝓦𝗈𝖗𝖑𝘥¡'|iconv -t asCIi//TRANSLIT
Đối với những người không cài đặt một phông chữ thích hợp, nó trông như thế này:
Đây là hexdump:
00000000 65 63 68 6f 20 27 f0 9d 93 97 f0 9d 90 9e f0 9d |echo '..........|
00000010 91 99 f0 9d 92 8d f0 9d 93 b8 e2 80 8a f0 9d 93 |................|
00000020 a6 f0 9d 97 88 f0 9d 96 97 f0 9d 96 91 f0 9d 98 |................|
00000030 a5 c2 a1 27 7c 69 63 6f 6e 76 09 2d 74 09 61 73 |...'|iconv.-t.as|
00000040 43 49 69 2f 2f 54 52 41 4e 53 4c 49 54 0a |CIi//TRANSLIT.|
0000004e
Bạn phải chạy nó trên một máy có bộ ký tự mặc định là utf-8. Tôi đã thử trên OSX10.8 bằng iTerm2 với môi trường sau:
PHP 5.4
Cái này sử dụng zLib: (tiếc là nó sử dụng các ký tự e
và o
)
<?=gzuncompress('x▒▒H▒▒▒W(▒/▒IQ▒!qh');
Hexdump:
00000000 3c 3f 3d 67 7a 75 6e 63 6f 6d 70 72 65 73 73 28 |<?=gzuncompress(|
00000010 27 78 9c f3 48 cd c9 c9 57 28 cf 2f ca 49 51 e4 |'x..H...W(./.IQ.|
00000020 02 00 21 71 04 68 27 29 3b |..!q.h');|
00000029
+1
Đây là mã ruby 2.0 tôi đã sử dụng để kiểm tra các bản sao:
d=ARGF.read
p [d.split(//),d.unpack('C*')].map{|x|x.inject(Hash.new(0)){|i,s|i[s]+=1;i}.select{|k,v|v>2}}