Cùng mã ký tự khác nhau


26

Lưu ý: Thử thách này chỉ cho phép câu trả lời bằng các ngôn ngữ được biên dịch

Bài tập

Nhiệm vụ của bạn khá đơn giản, tạo hai chương trình khác nhau mà khi biên dịch sẽ dẫn đến cùng một đầu ra.

Chấm điểm

Đây là nơi mà niềm vui đến. Điểm của bạn sẽ là số byte duy nhất có trong chính xác một chương trình. Ví dụ: nếu hai chương trình của bạn (được mã hóa trong mã IBM trang 437 ) là

☻☻Program A

☺Program B

Các nhân vật trong chính xác một chương trình là

☻☺AB

Do đó, điểm số là 4. Lưu ý xuất hiện hai lần trong chương trình đầu tiên nhưng chỉ được tính một lần.

Mục tiêu của bạn là đạt điểm cao nhất, điểm cao nhất có thể là 256.

Đây là một chương trình tính điểm hoạt động cho các chương trình được mã hóa ASCII.

Quy định

  • Mỗi byte trong cả hai chương trình sẽ có thể được thay thế bằng một byte khác nhau khiến chương trình biên dịch thành một kết quả khác nhau hoặc không thể biên dịch tất cả cùng nhau. Loại bỏ bất kỳ byte nên làm như vậy.

  • Bạn có thể sử dụng bất kỳ cờ biên dịch nào miễn là cả hai chương trình được chạy với cùng một cờ.

  • Quá trình biên dịch kết quả phải là tĩnh (nghĩa là không nên thay đổi từ chạy sang chạy), nếu kết quả thay đổi từ máy này sang máy khác cho biết máy dự định chạy trên đó.

  • Đầu ra của quá trình biên dịch phải là byte cho byte giống hệt nhau không "tương đương" hoặc "tương tự đủ".

  • Đầu ra của quá trình biên dịch phải không trống

  • Cảnh báo / Lỗi không cần giống nhau giữa các phần tổng hợp

  • Nếu chương trình hoặc phần biên dịch bao gồm các ký tự không thể in được, hãy chắc chắn bao gồm một hexdump. Mặc dù nó không phải là kỹ thuật cần thiết.


Điều này khá không rõ ràng, bởi vì người ta có thể khai báo một biến có tên abcdefghijqlmnop...để sử dụng hơn 20 ký tự duy nhất. Điều này có được phép không?
Ông Xcoder

1
@ Mr.Xcoder Miễn là tuân theo quy định đầu tiên (có lẽ là không).
Thuật sĩ lúa mì

Đây là một Code-Bowlingcâu hỏi tuyệt vời !
Albert Renshaw

1
Tạo một công cụ chấm điểm trực tuyến dễ dàng mà không yêu cầu bạn phải thoát mọi thứ / sửa đổi mã để phù hợp với chuỗi đầu vào của python trong TIO, chỉ trong trường hợp đó là vấn đề đối với bất kỳ ai: jsfiddle.net/vybsgh4p
Albert Renshaw

Ai đó có thể có thể tạo câu trả lời trong CoffeeScript
mbomb007

Câu trả lời:


18

Perl, điểm số 254 + 2 = 256

Đây là một kết xuất hex của một chương trình:

00000000: 6c65 6e67 7468 2700 0102 0304 0506 0708  length'.........
00000010: 090a 0b0c 0d0e 0f10 1112 1314 1516 1718  ................
00000020: 191a 1b1c 1d1e 1f20 2123 2425 2628 292a  ....... !#$%&()*
00000030: 2b2c 2d2e 2f30 3132 3334 3536 3738 393a  +,-./0123456789:
00000040: 3b3c 3d3e 3f40 4142 4344 4546 4748 494a  ;<=>?@ABCDEFGHIJ
00000050: 4b4c 4d4e 4f50 5152 5354 5556 5758 595a  KLMNOPQRSTUVWXYZ
00000060: 5b5d 5e5f 6061 6263 6465 6667 6869 6a6b  []^_`abcdefghijk
00000070: 6c6d 6e6f 7071 7273 7475 7677 7879 7a7b  lmnopqrstuvwxyz{
00000080: 7c7d 7e7f 8081 8283 8485 8687 8889 8a8b  |}~.............
00000090: 8c8d 8e8f 9091 9293 9495 9697 9899 9a9b  ................
000000a0: 9c9d 9e9f a0a1 a2a3 a4a5 a6a7 a8a9 aaab  ................
000000b0: acad aeaf b0b1 b2b3 b4b5 b6b7 b8b9 babb  ................
000000c0: bcbd bebf c0c1 c2c3 c4c5 c6c7 c8c9 cacb  ................
000000d0: cccd cecf d0d1 d2d3 d4d5 d6d7 d8d9 dadb  ................
000000e0: dcdd dedf e0e1 e2e3 e4e5 e6e7 e8e9 eaeb  ................
000000f0: eced eeef f0f1 f2f3 f4f5 f6f7 f8f9 fafb  ................
00000100: fcfd feff 273d 3d32 3533 6f72 2078 2829  ....'==253or x()

và đây là chương trình khác:

"\\"

Perl thường không nghĩ về một ngôn ngữ được biên dịch, nhưng nó là; đầu tiên nó được biên dịch thành mã byte, và sau đó mã byte được thực thi. Bạn có thể áp dụng bộ lọc trên mã byte (ví dụ để kết xuất nó thay vì chạy chương trình) bằng -MOtùy chọn. Cả hai chương trình này đều được biên dịch thành mã byte sau (được phân tách bằng cách sử dụng -MO=Terse):

LISTOP (0x564fcd99f020) leave [1] 
    OP (0x564fcd99f148) enter 
    COP (0x564fcd99f068) nextstate 
    OP (0x564fcd99f100) null [5] 

Giải trình

Perl thay thế tất cả các câu lệnh không có hiệu lực (chẳng hạn như chính chuỗi ký tự) bằng câu lệnh "mã hóa không có hiệu lực" được mã hóa cứng trong mã byte kết quả, vì vậy cả hai chương trình đều biên dịch theo cùng một thứ. Về mặt thay thế ký tự, việc thay thế hầu hết các ký tự từ chương trình 1 bằng dấu nháy đơn sẽ khiến nó không thể biên dịch (hoặc thay thế dấu nháy đơn 0). Trong chương trình 2, việc thay thế bất kỳ ký tự nào csẽ khiến chương trình không biên dịch được (như \ccó một đối số).

Đối với việc xóa ký tự, phiên bản đầu tiên của câu trả lời này có trước "quy tắc làm cứng bức xạ" (việc xóa bất kỳ ký tự nào cũng phải thay đổi hành vi của chương trình). Phiên bản cập nhật, làm cứng bức xạ này hoạt động thông qua việc sử dụng tổng kiểm tra; nếu xóa một ký tự không hoàn toàn gây ra lỗi cú pháp, mã sẽ biên dịch thành một cuộc gọi đến hàm không tồn tại x. Trình biên dịch Perl không tối ưu hóa cuộc gọi trong trường hợp nó được thực hiện (và nói chung dường như không biết rằng hàm không tồn tại), và do đó đầu ra là khác nhau. Tuy nhiên, thư mục không đổi của Perl có khả năng thấy rằng chương trình không bị đột biến là một câu lệnh đơn lẻ không có tác dụng, và do đó tối ưu hóa toàn bộ mọi thứ thành một câu lệnh như trước đây.

Ban đầu tôi đã đọc sai câu hỏi khi chỉ đếm các ký tự duy nhất từ ​​một chương trình và cố gắng tối ưu hóa cho điều đó. Rõ ràng, chương trình 2 cần chứa ít nhất một ký tự để tạo opcode "tuyên bố không có hiệu lực", nghĩa là điểm số tốt nhất có thể có trong một chương trình là 255. Tôi chưa tìm được cách đưa dấu gạch chéo ngược vào chương trình 1 theo cách mà nhân vật ngay lập tức không thể bị thay thế theo cách khiến chương trình bị phá vỡ, nhưng nó sẽ không làm tôi ngạc nhiên nếu có thể (dẫn đến số điểm 255 + 1 = 256 ).


@WheatWizard: Thử thách sẽ dễ dàng hơn một chút, nhưng tôi nghĩ rằng tôi có thể điều chỉnh câu trả lời này để làm việc với quy định như vậy thông qua thủ thuật kiểm tra thông thường (mà Perl có khả năng tối ưu hóa). Tôi sẽ xóa câu trả lời này và hủy xóa nó sau khi tôi có câu trả lời mới.

1
@WheatWizard: Và đã xong. Hóa ra nó không quá khó để cập nhật.

15

C, 231

Chương trình A

i[]={'','','','','','','',','   ','
                                       ','
                                          ','','','','','','','','','','','','','','','','','','',' ','!','"','#','$','%','&','\'','(',')','*','+',',','-','.','/','0','1','2','3','4','5','6','7','8','9',':',';','<','=','>','?','@','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z','[','\\',']','^','_','`','a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z','{','|','}','~','','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�','�'};main(){}

Rất nhiều dấu vết ở trên. Đây là hexdump xxd:

00000000: 695b 5d3d 7b27 0127 2c27 0227 2c27 0327  i[]={'.','.','.'
00000010: 2c27 0427 2c27 0527 2c27 0627 2c27 0727  ,'.','.','.','.'
00000020: 2c27 0827 2c27 0927 2c27 0b27 2c27 0c27  ,'.','.','.','.'
00000030: 2c27 0e27 2c27 0f27 2c27 1027 2c27 1127  ,'.','.','.','.'
00000040: 2c27 1227 2c27 1327 2c27 1427 2c27 1527  ,'.','.','.','.'
00000050: 2c27 1627 2c27 1727 2c27 1827 2c27 1927  ,'.','.','.','.'
00000060: 2c27 1a27 2c27 1b27 2c27 1c27 2c27 1d27  ,'.','.','.','.'
00000070: 2c27 1e27 2c27 1f27 2c27 2027 2c27 2127  ,'.','.',' ','!'
00000080: 2c27 2227 2c27 2327 2c27 2427 2c27 2527  ,'"','#','$','%'
00000090: 2c27 2627 2c27 5c27 272c 2728 272c 2729  ,'&','\'','(',')
000000a0: 272c 272a 272c 272b 272c 272c 272c 272d  ','*','+',',','-
000000b0: 272c 272e 272c 272f 272c 2730 272c 2731  ','.','/','0','1
000000c0: 272c 2732 272c 2733 272c 2734 272c 2735  ','2','3','4','5
000000d0: 272c 2736 272c 2737 272c 2738 272c 2739  ','6','7','8','9
000000e0: 272c 273a 272c 273b 272c 273c 272c 273d  ',':',';','<','=
000000f0: 272c 273e 272c 273f 272c 2740 272c 2741  ','>','?','@','A
00000100: 272c 2742 272c 2743 272c 2744 272c 2745  ','B','C','D','E
00000110: 272c 2746 272c 2747 272c 2748 272c 2749  ','F','G','H','I
00000120: 272c 274a 272c 274b 272c 274c 272c 274d  ','J','K','L','M
00000130: 272c 274e 272c 274f 272c 2750 272c 2751  ','N','O','P','Q
00000140: 272c 2752 272c 2753 272c 2754 272c 2755  ','R','S','T','U
00000150: 272c 2756 272c 2757 272c 2758 272c 2759  ','V','W','X','Y
00000160: 272c 275a 272c 275b 272c 275c 5c27 2c27  ','Z','[','\\','
00000170: 5d27 2c27 5e27 2c27 5f27 2c27 6027 2c27  ]','^','_','`','
00000180: 6127 2c27 6227 2c27 6327 2c27 6427 2c27  a','b','c','d','
00000190: 6527 2c27 6627 2c27 6727 2c27 6827 2c27  e','f','g','h','
000001a0: 6927 2c27 6a27 2c27 6b27 2c27 6c27 2c27  i','j','k','l','
000001b0: 6d27 2c27 6e27 2c27 6f27 2c27 7027 2c27  m','n','o','p','
000001c0: 7127 2c27 7227 2c27 7327 2c27 7427 2c27  q','r','s','t','
000001d0: 7527 2c27 7627 2c27 7727 2c27 7827 2c27  u','v','w','x','
000001e0: 7927 2c27 7a27 2c27 7b27 2c27 7c27 2c27  y','z','{','|','
000001f0: 7d27 2c27 7e27 2c27 7f27 2c27 8027 2c27  }','~','.','.','
00000200: 8127 2c27 8227 2c27 8327 2c27 8427 2c27  .','.','.','.','
00000210: 8527 2c27 8627 2c27 8727 2c27 8827 2c27  .','.','.','.','
00000220: 8927 2c27 8a27 2c27 8b27 2c27 8c27 2c27  .','.','.','.','
00000230: 8d27 2c27 8e27 2c27 8f27 2c27 9027 2c27  .','.','.','.','
00000240: 9127 2c27 9227 2c27 9327 2c27 9427 2c27  .','.','.','.','
00000250: 9527 2c27 9627 2c27 9727 2c27 9827 2c27  .','.','.','.','
00000260: 9927 2c27 9a27 2c27 9b27 2c27 9c27 2c27  .','.','.','.','
00000270: 9d27 2c27 9e27 2c27 9f27 2c27 a027 2c27  .','.','.','.','
00000280: a127 2c27 a227 2c27 a327 2c27 a427 2c27  .','.','.','.','
00000290: a527 2c27 a627 2c27 a727 2c27 a827 2c27  .','.','.','.','
000002a0: a927 2c27 aa27 2c27 ab27 2c27 ac27 2c27  .','.','.','.','
000002b0: ad27 2c27 ae27 2c27 af27 2c27 b027 2c27  .','.','.','.','
000002c0: b127 2c27 b227 2c27 b327 2c27 b427 2c27  .','.','.','.','
000002d0: b527 2c27 b627 2c27 b727 2c27 b827 2c27  .','.','.','.','
000002e0: b927 2c27 ba27 2c27 bb27 2c27 bc27 2c27  .','.','.','.','
000002f0: bd27 2c27 be27 2c27 bf27 2c27 c027 2c27  .','.','.','.','
00000300: c127 2c27 c227 2c27 c327 2c27 c427 2c27  .','.','.','.','
00000310: c527 2c27 c627 2c27 c727 2c27 c827 2c27  .','.','.','.','
00000320: c927 2c27 ca27 2c27 cb27 2c27 cc27 2c27  .','.','.','.','
00000330: cd27 2c27 ce27 2c27 cf27 2c27 d027 2c27  .','.','.','.','
00000340: d127 2c27 d227 2c27 d327 2c27 d427 2c27  .','.','.','.','
00000350: d527 2c27 d627 2c27 d727 2c27 d827 2c27  .','.','.','.','
00000360: d927 2c27 da27 2c27 db27 2c27 dc27 2c27  .','.','.','.','
00000370: dd27 2c27 de27 2c27 df27 2c27 e027 2c27  .','.','.','.','
00000380: e127 2c27 e227 2c27 e327 2c27 e427 2c27  .','.','.','.','
00000390: e527 2c27 e627 2c27 e727 2c27 e827 2c27  .','.','.','.','
000003a0: e927 2c27 ea27 2c27 eb27 2c27 ec27 2c27  .','.','.','.','
000003b0: ed27 2c27 ee27 2c27 ef27 2c27 f027 2c27  .','.','.','.','
000003c0: f127 2c27 f227 2c27 f327 2c27 f427 2c27  .','.','.','.','
000003d0: f527 2c27 f627 2c27 f727 2c27 f827 2c27  .','.','.','.','
000003e0: f927 2c27 fa27 2c27 fb27 2c27 fc27 2c27  .','.','.','.','
000003f0: fd27 2c27 fe27 2c27 ff27 7d3b 6d61 696e  .','.','.'};main
00000400: 2829 7b7d 0a                             (){}.

Chương trình B

i[]={1,2,3,4,5,6,7,010,011,013,014,016,017,020,021,022,023,024,025,026,027,030,031,032,033,034,035,036,037,040,041,042,043,044,045,046,047,050,051,052,053,054,055,056,057,060,061,062,063,064,065,066,067,070,071,072,073,074,075,076,077,0100,0101,0102,0103,0104,0105,0106,0107,0110,0111,0112,0113,0114,0115,0116,0117,0120,0121,0122,0123,0124,0125,0126,0127,0130,0131,0132,0133,0134,0135,0136,0137,0140,0141,0142,0143,0144,0145,0146,0147,0150,0151,0152,0153,0154,0155,0156,0157,0160,0161,0162,0163,0164,0165,0166,0167,0170,0171,0172,0173,0174,0175,0176,0177,-0200,-0177,-0176,-0175,-0174,-0173,-0172,-0171,-0170,-0167,-0166,-0165,-0164,-0163,-0162,-0161,-0160,-0157,-0156,-0155,-0154,-0153,-0152,-0151,-0150,-0147,-0146,-0145,-0144,-0143,-0142,-0141,-0140,-0137,-0136,-0135,-0134,-0133,-0132,-0131,-0130,-0127,-0126,-0125,-0124,-0123,-0122,-0121,-0120,-0117,-0116,-0115,-0114,-0113,-0112,-0111,-0110,-0107,-0106,-0105,-0104,-0103,-0102,-0101,-0100,-077,-076,-075,-074,-073,-072,-071,-070,-067,-066,-065,-064,-063,-062,-061,-060,-057,-056,-055,-054,-053,-052,-051,-050,-047,-046,-045,-044,-043,-042,-041,-040,-037,-036,-035,-034,-033,-032,-031,-030,-027,-026,-025,-024,-023,-022,-021,-020,-017,-016,-015,-014,-013,-012,-011,-010,-7,-6,-5,-4,-3,-2,-1};main(){}

Chúng biên dịch chính xác cùng mã đối tượng. GCC nhúng tên tệp vào mã đối tượng, vì vậy bạn sẽ cần đặt các tệp cùng tên (trong các thư mục khác nhau).

Tôi đã lo lắng rằng thực tế là không có tài liệu tham khảo nào icó thể khiến trình biên dịch tối ưu hóa hoàn toàn biến này, nhưng tôi nghĩ rằng làm cho nó trở thành một đảm bảo toàn cầu rằng nó sẽ có mặt trong đối tượng. Điều này có thể được xác minh bằng cách kiểm tra lắp ráp được tạo ra:

    .file   "diffchar.c"
    .globl  i
    .data
    .align 32
    .type   i, @object
    .size   i, 1012
i:
    .long   1
    .long   2
    .long   3
    .long   4
    .long   5
    .long   6
    .long   7
    .long   8
    .long   9
    .long   11
    .long   12
    .long   14
    .long   15
    .long   16
    .long   17
    .long   18
    .long   19
    .long   20
    .long   21
    .long   22
    .long   23
    .long   24
    .long   25
    .long   26
    .long   27
    .long   28
    .long   29
    .long   30
    .long   31
    .long   32
    .long   33
    .long   34
    .long   35
    .long   36
    .long   37
    .long   38
    .long   39
    .long   40
    .long   41
    .long   42
    .long   43
    .long   44
    .long   45
    .long   46
    .long   47
    .long   48
    .long   49
    .long   50
    .long   51
    .long   52
    .long   53
    .long   54
    .long   55
    .long   56
    .long   57
    .long   58
    .long   59
    .long   60
    .long   61
    .long   62
    .long   63
    .long   64
    .long   65
    .long   66
    .long   67
    .long   68
    .long   69
    .long   70
    .long   71
    .long   72
    .long   73
    .long   74
    .long   75
    .long   76
    .long   77
    .long   78
    .long   79
    .long   80
    .long   81
    .long   82
    .long   83
    .long   84
    .long   85
    .long   86
    .long   87
    .long   88
    .long   89
    .long   90
    .long   91
    .long   92
    .long   93
    .long   94
    .long   95
    .long   96
    .long   97
    .long   98
    .long   99
    .long   100
    .long   101
    .long   102
    .long   103
    .long   104
    .long   105
    .long   106
    .long   107
    .long   108
    .long   109
    .long   110
    .long   111
    .long   112
    .long   113
    .long   114
    .long   115
    .long   116
    .long   117
    .long   118
    .long   119
    .long   120
    .long   121
    .long   122
    .long   123
    .long   124
    .long   125
    .long   126
    .long   127
    .long   -128
    .long   -127
    .long   -126
    .long   -125
    .long   -124
    .long   -123
    .long   -122
    .long   -121
    .long   -120
    .long   -119
    .long   -118
    .long   -117
    .long   -116
    .long   -115
    .long   -114
    .long   -113
    .long   -112
    .long   -111
    .long   -110
    .long   -109
    .long   -108
    .long   -107
    .long   -106
    .long   -105
    .long   -104
    .long   -103
    .long   -102
    .long   -101
    .long   -100
    .long   -99
    .long   -98
    .long   -97
    .long   -96
    .long   -95
    .long   -94
    .long   -93
    .long   -92
    .long   -91
    .long   -90
    .long   -89
    .long   -88
    .long   -87
    .long   -86
    .long   -85
    .long   -84
    .long   -83
    .long   -82
    .long   -81
    .long   -80
    .long   -79
    .long   -78
    .long   -77
    .long   -76
    .long   -75
    .long   -74
    .long   -73
    .long   -72
    .long   -71
    .long   -70
    .long   -69
    .long   -68
    .long   -67
    .long   -66
    .long   -65
    .long   -64
    .long   -63
    .long   -62
    .long   -61
    .long   -60
    .long   -59
    .long   -58
    .long   -57
    .long   -56
    .long   -55
    .long   -54
    .long   -53
    .long   -52
    .long   -51
    .long   -50
    .long   -49
    .long   -48
    .long   -47
    .long   -46
    .long   -45
    .long   -44
    .long   -43
    .long   -42
    .long   -41
    .long   -40
    .long   -39
    .long   -38
    .long   -37
    .long   -36
    .long   -35
    .long   -34
    .long   -33
    .long   -32
    .long   -31
    .long   -30
    .long   -29
    .long   -28
    .long   -27
    .long   -26
    .long   -25
    .long   -24
    .long   -23
    .long   -22
    .long   -21
    .long   -20
    .long   -19
    .long   -18
    .long   -17
    .long   -16
    .long   -15
    .long   -14
    .long   -13
    .long   -12
    .long   -11
    .long   -10
    .long   -9
    .long   -8
    .long   -7
    .long   -6
    .long   -5
    .long   -4
    .long   -3
    .long   -2
    .long   -1
    .text
    .globl  main
    .type   main, @function
main:
.LFB0:
    .cfi_startproc
    pushq   %rbp
    .cfi_def_cfa_offset 16
    .cfi_offset 6, -16
    movq    %rsp, %rbp
    .cfi_def_cfa_register 6
    movl    $0, %eax
    popq    %rbp
    .cfi_def_cfa 7, 8
    ret
    .cfi_endproc
.LFE0:
    .size   main, .-main
    .ident  "GCC: (Ubuntu 5.4.0-6ubuntu1~16.04.4) 5.4.0 20160609"
    .section    .note.GNU-stack,"",@progbits

Lưu ý rằng trong chương trình B, (hầu hết) các giá trị char được đưa ra trong bát phân. Chúng cũng có thể được đưa ra dưới dạng thập phân, nhưng bằng cách sử dụng bát phân, chúng ta có được một vài ký tự phụ - 89- trong tập khác biệt.

GCC dường như không thích CR, LF và (vì lý do rõ ràng) các ký tự NUL bên trong các trích dẫn đơn ''.

Hãy thử trực tuyến và điểm số .


Có cách nào để sử dụng một chuỗi ký tự thay thế nếu định dạng mảng cồng kềnh? (Tôi không biết nhiều về C)
Wheat Wizard

@WheatWizard Có, nhưng sau đó, biến cần phải được khai báo rõ ràng charthay vì ngầm định int, gây bất lợi cho điểm số.
Chấn thương kỹ thuật số

Hơn 200! Làm tốt lắm
Phù thủy lúa mì

Đối với các hằng số bát phân cũng là số thập phân hợp lệ có cùng giá trị, bạn cần xóa các số 0 đang xóa, nếu không chúng có thể bị xóa mà không phá vỡ chương trình. Bạn cũng có thể cải thiện điểm số bằng cách sử dụng các bản vẽ sơ đồ và / hoặc chữ ba trong một trong các chương trình?

@ ais523 Có, điểm hay về các giá trị mơ hồ bát phân / thập phân - Tôi đã sửa các giá trị đó. Tôi sẽ khám phá đồ thị {di, tri} sau ...
Chấn thương kỹ thuật số

4

Con trăn, điểm 16 26 27 28

Nhân vật độc đáo: -+;132547698<ACBEDFOXabopsx|

Tính điểm

Chương trình 1:

def y():
 if 0: 0xBCAFD0|0XE|(0o4<<0O4)|48;

 return 0

Trong chương trình 1, có 5 khoảng trống trong dòng dường như trống.

Chương trình 2:

def y():
 if 0:return--12365790+(0b1110000)
 pass
 return 0

Một số trợ giúp đã được tìm thấy với mã nguồn tối ưu hóa lổ nhìn trộm .

Đã thử nghiệm với kịch bản trợ giúp này: Hãy thử trực tuyến!


2

Python 3.6, 2 3 5 6

Chương trình 1:

z=11_11;a=41_68;y=None;x=5_2_7_9;x*x

Chương trình 2:

z=1111;a=4168;y=None;x=1111+4168;x*x

Python không được biên dịch bình thường, nhưng nó biên dịch mã nguồn của nó thành các tệp pyc. Điều quan trọng, việc biên dịch như vậy bao gồm một vượt qua tối ưu hóa thay đổi "1111 + 4168" thành 5279. Các dấu gạch dưới phục vụ hai mục đích: một trong số đó là thêm một vào điểm số và cái còn lại là giữ độ dài, được lưu trữ trong pyc tiêu đề giống nhau. Tất cả các bài tập biến khác ngoài 'x' là để giữ co_constsđúng thứ tự. Các x*xcuối cùng phục vụ để giữ co_stacksizegiống nhau.


Tôi cũng đang sử dụng 3.6.0. Đảm bảo rằng các tệp bạn biên dịch có cùng mtime và tên tệp và thêm hai khoảng trắng ở cuối tệp đầu tiên. (Tôi đã kiểm tra điều này bằng cách sử dụng hàm dựng sẵn compile, không thêm tiêu đề. chỉ áp dụng cho tiêu đề
pppery

Thời gian tập tin được sửa đổi lần cuối. Python chuẩn bị mã byte của nó với mã hóa vào thời điểm này, vì vậy nó có thể tự động làm mới mã byte cũ
pppery

1
Có, sử dụng os.utimechức năng
pppery


Rất tiếc, tôi đã giải thích sai điều này như một môn đánh gôn không phải là một thử thách chơi bowling
pppery

0

FASM, 254

00000000h: 64 62 20 27 01 02 03 04 05 06 07 08 0B 0C 0E 0F ; db '............
00000010h: 10 11 12 13 14 15 16 17 18 19 1B 1C 1D 1E 1F 21 ; ...............!
00000020h: 22 23 24 25 26 28 29 2A 2B 2D 2E 2F 3A 3B 3C 3D ; "#$%&()*+-./:;<=
00000030h: 3E 3F 40 41 43 45 46 47 48 49 4A 4B 4C 4D 4E 4F ; >?@ACEFGHIJKLMNO
00000040h: 50 51 52 53 54 55 56 57 58 59 5A 5B 5C 5D 5E 5F ; PQRSTUVWXYZ[\]^_
00000050h: 60 61 63 65 66 67 68 69 6A 6B 6C 6D 6E 6F 70 71 ; `acefghijklmnopq
00000060h: 72 73 74 75 76 77 78 79 7A 7B 7C 7D 7E 7F 80 81 ; 
00000070h: 82 83 84 85 86 87 88 89 8A 8B 8C 8D 8E 8F 90 91 ; 
00000080h: 92 93 94 95 96 97 98 99 9A 9B 9C 9D 9E 9F A0 A1 ; 
00000090h: A2 A3 A4 A5 A6 A7 A8 A9 AA AB AC AD AE AF B0 B1 ; 
000000a0h: B2 B3 B4 B5 B6 B7 B8 B9 BA BB BC BD BE BF C0 C1 ; 
000000b0h: C2 C3 C4 C5 C6 C7 C8 C9 CA CB CC CD CE CF D0 D1 ; 
000000c0h: D2 D3 D4 D5 D6 D7 D8 D9 DA DB DC DD DE DF E0 E1 ; 
000000d0h: E2 E3 E4 E5 E6 E7 E8 E9 EA EB EC ED EE EF F0 27 ; 
000000e0h: 0D 64 62 20 27 F1 F2 F3 F4 F5 F6 F7 F8 F9 FA FB ; 
000000f0h: FC FD FE FF 27                                  ; 

DB  1,2,3,4,5,6,7,8,11,12,14,15,16,17,18,19,20,21,22,23,24,25,27,28,29,30,31,33,34,35,36,37,38,40,41,42,43,45,46,47,58,59,60,61,62,63,64,65,67,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,99,101,102,103,104,105,106,107,108,109,110,111,112,113,114,115,116,117,118,119,120,121,122,123,124,125,126,127,128,129,130,131,132,133,134,135,136,137,138,139,140,141,142,143,144,145,146,147,148,149,150,151,152,153,154,155,156,157,158,159,160,161,162,163,164,165,166,167,168,169,170,171,172,173,174,175,176,177,178,179,180,181,182,183,184,185,186,187,188,189,190,191,192,193,194,195,196,197,198,199,200,201,202,203,204,205,206,207,208,209,210,211,212,213,214,215,216,217,218,219,220,221,222,223,224,225,226,227,228,229,230,231,232,233,234,235,236,237,238,239,240,241,242,243,244,245,246,247,248,249,250,251
DB  252,253,254,255

không 0x00 và 0x1A vì fasm không hỗ trợ hai biểu tượng


Cả hai đều sử dụng dòng mới nhưng một người sử dụng \ n trong khi người khác sử dụng \ r
l4m2
Khi sử dụng trang web của chúng tôi, bạn xác nhận rằng bạn đã đọc và hiểu Chính sách cookieChính sách bảo mật của chúng tôi.
Licensed under cc by-sa 3.0 with attribution required.