gpt4 book ai didi

php - 智能PHP压缩代码

转载 作者:可可西里 更新时间:2023-11-01 12:52:23 25 4
gpt4 key购买 nike

所以我看到了这个关于“编程难题和代码高尔夫”的聪明话题: We're not strangers... 。最佳答案是打印 Never Gonna Give You Up 歌词的 PHP 代码。它只有 543 个字节长。

我试图理解这段 PHP 代码,但我不明白它是如何工作的。我认为这是一种基于语法的压缩,但我不知道如何使用未声明的常量,如

<?php range('-', T);

所以这是代码。这是如何工作的?

<?=str_replace(range('-',T),split(q,"
I justCannaLE?2Gotta >u=Msta=.q
Ng1Nlet? downNrun<rH=5desMt?N>cryNsayRoodbyeNtE< lie5hurt?q

We'T3n each@Jor s8lSg6r hear9<ch: but6;Lo7hyL7BInsideCe both3Cha9Ro: S
We3KeRa45we;QplBq1)O)NgiT, nPgiT
(GqiT? upq howFJeel:
q knowqmeq<= q
YHq8sqo qt's beenqingq'req aqndqmake? q yHq othMqAqay it
q wqDqellq I'mqGqouqIq fqLhq tqerq
NPq
(OohqeTrQqRSna q gqonqve"),"We; n7trangMsL8loT63Ke rules5s8d8I
AJull commit4nt'sChatFKink: of6CHldn'tRetKisJrom<ny@Ruy-/A= if?<sk 42DS'tLE 4?;Lo8bli=L7ee..
O,R1)O,R001)/-..");

参见 it working on Ideone .

最佳答案

让我们一一分析str_replace参数。

range('-',T)

range()函数返回一个数组,其中的元素从第一个参数跨越到第二个参数。字符由它们的 ASCII 值来考虑,所以结果是

Array
(
[0] => -
[1] => .
[2] => /
[3] => 0
[4] => 1
[5] => 2
[6] => 3
[7] => 4
[8] => 5
[9] => 6
[10] => 7
[11] => 8
[12] => 9
[13] => :
[14] => ;
[15] => <
[16] => =
[17] => >
[18] => ?
[19] => @
[20] => A
[21] => B
[22] => C
[23] => D
[24] => E
[25] => F
[26] => G
[27] => H
[28] => I
[29] => J
[30] => K
[31] => L
[32] => M
[33] => N
[34] => O
[35] => P
[36] => Q
[37] => R
[38] => S
[39] => T
)

为什么是 T 而不是 "T"? PHP 有一个错误特性,它会把未定义的常量当作内容与常量名称相同的字符串来计算。常量 T 未定义,因此它与 "T" 相同,后者为代码高尔夫目的保存两个字符。后面的q也是如此。如果服务器有错误报告,它将显示关于未定义常量的警告。

split(q,"I justCannaLE?2Gotta >u=Msta=.q...");

这会将字符串拆分为 q 个字符处的数组。同样,这使得代码比使用数组文字更短。结果:

Array
(
[0] =>
I justCannaLE?2Gotta >u=Msta=.
[1] =>
Ng1Nlet? downNrun<rH=5desMt?N>cryNsayRoodbyeNtE< lie5hurt?
[2] =>

We'T3n each@Jor s8lSg6r hear9<ch: but6;Lo7hyL7BInsideCe both3Cha9Ro: S
We3KeRa45we;QplB
[3] => 1)O)NgiT, nPgiT
(G
[4] => iT? up
[5] => howFJeel:

[6] => know
[7] => me
[8] => <=
[9] =>
YH
[10] => 8s
[11] => o
[12] => t's been
[13] => ing
[14] => 're
[15] => a
[16] => nd
[17] => make?
[18] => yH
[19] => othM
[20] => A
[21] => ay it

[22] => w
[23] => D
[24] => ell
[25] => I'm
[26] => G
[27] => ou
[28] => I
[29] => f
[30] => Lh
[31] => t
[32] => er
[33] =>
NP
[34] =>
(Ooh
[35] => eTrQ
[36] => RSna
[37] => g
[38] => on
[39] => ve
)

最后一个参数是目标字符串。

"We; n7trangMsL8loT63Ke rules5s8d8I
AJull commit4nt'sChatFKink: of6CHldn'tRetKisJrom<ny@Ruy-/A= if?<sk 42DS'tLE 4?;Lo8bli=L7ee..
O,R1)O,R001)/-.."

如果您将数组作为针和大海捞针传递给 str_replace(),则一次完成一个替换。为简单起见,我们仅将 "We; n7trangMs" 作为目标字符串并从 ; 开始替换。将"7"替换为"8s"后的第一步(第二个数组中的对应替换):

"We; n8strangMs"

然后将 "8" 替换为 "o "

"We; no strangMs"

";""re"

"We're no strangMs"

“M”“er”

"We're no strangers"

简而言之,这是一种基本的压缩算法,您可以在其中找到在原始文本中重复的字符序列,并将它们替换为单个字符。解压缩时,该字符将替换为原始序列。通过迭代运行进度,您可以再次压缩曾经压缩过的文本 ("o s" => "8s" => "7") .

关于php - 智能PHP压缩代码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18126871/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com