当前位置:首页 > 公众号精选 > 嵌入式微处理器
[导读]今天 Hacker News 上有个热帖讨论一个 C 程序,一次调用输出的井字棋游戏。 打开一看,原来是 2020 年 IOCCC 大赛的一个参赛作品: #include #define N(a) "%"#a"$hhn"#define O(a,b) "%10$"#a"d"N(b)#define U "%10$.*37$d"#define G(a) "%"#a"$s"

今天 Hacker News 上有个热帖讨论一个 程序,一次调用输出的井字棋游戏。



打开一看,原来是 2020 年 IOCCC 大赛的一个参赛作品:

#include <stdio.h>
#define N(a) "%"#a"$hhn"#define O(a,b) "%10$"#a"d"N(b)#define U "%10$.*37$d"#define G(a) "%"#a"$s"#define H(a,b) G(a)G(b)#define T(a) a a #define s(a) T(a)T(a)#define A(a) s(a)T(a)a#define n(a) A(a)a#define D(a) n(a)A(a)#define C(a) D(a)a#define R C(C(N(12)G(12)))#define o(a,b,c) C(H(a,a))D(G(a))C(H(b,b)G(b))n(G(b))O(32,c)R#define SS O(78,55)R "\n\033[2J\n%26$s";#define E(a,b,c,d) H(a,b)G(c)O(253,11)R G(11)O(255,11)R H(11,d)N(d)O(253,35)R#define S(a,b) O(254,11)H(a,b)N(68)R G(68)O(255,68)N(12)H(12,68)G(67)N(67)
char* fmt = O(10,39)N(40)N(41)N(42)N(43)N(66)N(69)N(24)O(22,65)O(5,70)O(8,44)N( 45)N(46)N (47)N(48)N( 49)N( 50)N( 51)N(52)N(53 )O( 28, 54)O(5, 55) O(2, 56)O(3,57)O( 4,58 )O(13, 73)O(4, 71 )N( 72)O (20,59 )N(60)N(61)N( 62)N (63)N (64)R R E(1,2, 3,13 )E(4, 5,6,13)E(7,8,9 ,13)E(1,4 ,7,13)E (2,5,8, 13)E( 3,6,9,13)E(1,5, 9,13)E(3 ,5,7,13 )E(14,15, 16,23) E(17,18,19,23)E( 20, 21, 22,23)E (14,17,20,23)E(15, 18,21,23)E(16,19, 22 ,23)E( 14, 18, 22,23)E(16,18,20, 23)R U O(255 ,38)R G ( 38)O( 255,36) R H(13,23)O(255, 11)R H(11,36) O(254 ,36) R G( 36 ) O( 255,36)R S(1,14 )S(2,15)S(3, 16)S(4, 17 )S (5, 18)S(6, 19)S(7,20)S(8, 21)S(9 ,22)H(13,23 )H(36, 67 )N(11)R G(11)""O(255, 25 )R s(C(G(11) ))n (G( 11) )G( 11)N(54)R C( "aa") s(A( G(25)))T (G(25))N (69)R o (14,1,26)o( 15, 2, 27)o (16,3,28 )o( 17,4, 29)o(18 ,5,30)o(19 ,6,31)o( 20,7,32)o (21,8,33)o (22 ,9, 34)n(C(U) )N( 68)R H( 36,13)G(23) N(11)R C(D( G(11))) D(G(11))G(68)N(68)R G(68)O(49,35)R H(13,23)G(67)N(11)R C(H(11,11)G( 11))A(G(11))C(H(36,36)G(36))s(G(36))O(32,58)R C(D(G(36)))A(G(36))SS
#define arg d+6,d+8,d+10,d+12,d+14,d+16,d+18,d+20,d+22,0,d+46,d+52,d+48,d+24,d\ +26,d+28,d+30,d+32,d+34,d+36,d+38,d+40,d+50,(scanf(d+126,d+4),d+(6\ -2)+18*(1-d[2]%2)+d[4]*2),d,d+66,d+68,d+70, d+78,d+80,d+82,d+90,d+\ 92,d+94,d+97,d+54,d[2],d+2,d+71,d+77,d+83,d+89,d+95,d+72,d+73,d+74\ ,d+75,d+76,d+84,d+85,d+86,d+87,d+88,d+100,d+101,d+96,d+102,d+99,d+\ 67,d+69,d+79,d+81,d+91,d+93,d+98,d+103,d+58,d+60,d+98,d+126,d+127,\ d+128,d+129
char d[538] = {1,0,10,0,10};
int main() { while(*d) printf(fmt, arg);}


截图:



是不是看着发晕?发晕就对了!


IOCCC  大赛全称:The International Obfuscated C Code Contest,国际 C 语言混乱代码大赛,目的是写出最有创意的最让人难以理解的 C 语言代码,并限制在 4 kb 以内。这项赛事也年头了,2020 年是第 27 次举办。


写这个程序的小哥 Carlini 已经在 GitHub 上解释了程序原理:



链接:

https://github.com/carlini/printf-tac-toe


本文授权转载自公众号“CPP开发者”,作者CPP开发者


-END-




推荐阅读



【01】STM32好找工作,所以学linux终究是错付了吗?
【02】锂电池充电慢?教你用 STM32 制作锂电池快充充电器
【03】stm32几种低功耗模式的实现和差别
【04】如何让STM32优雅地“说”hello world?
【05】stm32几种低功耗模式的实现和差别


免责声明:整理文章为传播相关技术,版权归原作者所有,如有侵权,请联系删除

免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

嵌入式ARM

扫描二维码,关注更多精彩内容

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
关闭
关闭