56
\$\begingroup\$

In an earlier challenge I asked code golfers to produce strings which copy each character in a string. For example:

TThhiiss iiss ddoouubbllee ssppeeaakk!!

This challenge is simply to detect if some text meets the definition of a double speak string.

  • There is an even number of characters.
  • When split into pairs, every pair consists of two of the same character.

The challenge

  • It's code golf, do it in few bytes.
  • Use any language you choose.
  • Please include a link to an online interpreter.
  • The code will accept some text.
  • For simplicity, the input will only consist of printable ASCII characters
  • It will return an indication of whether or not the input is double speak. It could be:
  • A boolean
  • Strings ('true', 'false', 'yes', 'no' etc)
  • Integers 0 or 1

Test Cases:

input -> output
aba -> false
aab -> false
abba -> false
aabb -> true
aaabb -> false
tthhiiss -> true
ttthhhiiisss -> false
asked Aug 6, 2019 at 15:31
\$\endgroup\$
12
  • 9
    \$\begingroup\$ May we error on inputs of length < 2? \$\endgroup\$ Commented Aug 6, 2019 at 16:06
  • 4
    \$\begingroup\$ Suggested test case: abba which should be falsey \$\endgroup\$ Commented Aug 6, 2019 at 16:29
  • 3
    \$\begingroup\$ Suggested test case: aabbbb which should be truthy \$\endgroup\$ Commented Aug 6, 2019 at 17:30
  • 2
    \$\begingroup\$ @val Well, I'm not going to argue with standard I/O \$\endgroup\$ Commented Aug 7, 2019 at 8:27
  • 4
    \$\begingroup\$ What about the empty string? \$\endgroup\$ Commented Aug 7, 2019 at 21:04

102 Answers 102

1
2 3 4
65
\$\begingroup\$

Python 3, 24 bytes

lambda s:s[::2]==s[1::2]

Try it online!

answered Aug 6, 2019 at 15:40
\$\endgroup\$
29
\$\begingroup\$

brainfuck, 20 bytes

Saved 1 byte thanks to Jo King.

+>,[>,[-<->]<[<],]<.

Try it online!

Readable output!

Takes input two characters at a time, and moves away from the 1 on the tape if any pair doesn't match. EOF is treated as 0 and thus handled automatically.

Output is a null byte if the string is not double speak, and 0x01 if it is. The readable version outputs these as characters at a cost of 14 bytes.

answered Aug 6, 2019 at 16:17
\$\endgroup\$
0
18
\$\begingroup\$

MATL, 4 bytes

Heda

Input is a string, enclosed with single qoutes. Output is 0 for double speak, 1 otherwise.

Try it online!

Explanation

Consider input 'TThhiiss iiss ddoouubbllee ssppeeaakk!!' as an example.

H % Push 2
 % STACK: 2
 % Implicit input (triggered because the next function requires two inputs): string 
 % STACK: 'TThhiiss iiss ddoouubbllee ssppeeaakk!!', 2
e % Reshape as a 2-column matrix of chars, in column-major order. Pads with char(0)
 % if needed. Note that char(0) cannot be present in the input
 % STACK: ['This is double speak!';
 'This is double speak!']
d % Difference of each column
 % STACK: [0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]
a % Any: gives 0 if and only if all elements are 0
 % STACK: 0
 % Implicit display
answered Aug 6, 2019 at 15:35
\$\endgroup\$
2
  • 14
    \$\begingroup\$ Um... who is "Heda"? :D \$\endgroup\$ Commented Aug 6, 2019 at 16:01
  • 12
    \$\begingroup\$ "Heda" is German for "Hey! You!" \$\endgroup\$ Commented Aug 9, 2019 at 12:47
14
\$\begingroup\$

05AB1E, (削除) 6 (削除ここまで) (削除) 5 (削除ここまで) 2 bytes

ιË

Input as a list of characters.

-3 bytes by porting @Shaggy's Japt answer, so make sure to upvote him!

Try it online or verify a few more test cases.

Explanation:

ι # Uninterleave the (implicit) input-list of characters
 # i.e. ["t","t","t","t","e","e","s","s","t","t","!","!","!"]
 # → [["t","t","e","s","t","!","!"],["t","t","e","s","t","!"]]
 Ë # Check if both inner lists are equal
 # → 0 (falsey)
 # (after which the result is output implicitly)
answered Aug 6, 2019 at 15:38
\$\endgroup\$
11
\$\begingroup\$

Japt, 4 bytes

ó r¶

Try it

ó r¶ :Implicit input of string
ó :Uniterleave
 r :Reduce by
 ¶ : Testing equality

Alternative

ó
\o

Try it

answered Aug 6, 2019 at 16:19
\$\endgroup\$
0
11
\$\begingroup\$

Stax, 5 bytes

しかく◄┼$Δ

Run and debug it

Procedure:

  • Calculate run-lengths.
  • Get GCD of array.
  • Is even?
answered Aug 6, 2019 at 18:04
\$\endgroup\$
2
  • \$\begingroup\$ Ahh, you got one that packs. Nice. \$\endgroup\$ Commented Aug 6, 2019 at 18:20
  • 1
    \$\begingroup\$ i like this algorithm! \$\endgroup\$ Commented Aug 6, 2019 at 18:51
10
\$\begingroup\$

Retina, 9 bytes

(.)1円
^$

Try it online.

Explanation:

Remove all pair of the same characters:

(.)1円

Check if there are no characters left:

^$
answered Aug 6, 2019 at 16:06
\$\endgroup\$
2
  • 1
    \$\begingroup\$ You can provide a more traditional output by using ^$ as your final stage. \$\endgroup\$ Commented Aug 6, 2019 at 16:38
  • \$\begingroup\$ @Neil Ah of course, thanks! That indeed looks better. I always think it's strange outputting false as truthy and true as falsey (but if it saves a byte and it's allowed, I will still use it). ;) But since this is an equal bytes solution outputting the expected results, this is better. \$\endgroup\$ Commented Aug 6, 2019 at 16:42
8
\$\begingroup\$

Jelly, 3 bytes

ŒœE

Try it online!

answered Aug 6, 2019 at 15:42
\$\endgroup\$
1
  • 1
    \$\begingroup\$ Hey I like this! It took me 80mns to do the same lol, I was like "hey let's learn Jelly now" then I learned. I was about to post this but looked if Jelly answers were already there... and then saw this ^^ My steps: ¹©s2L€=2Ạa®s2E€Ạ... ḢƝs2E€Ạ... but I couldn't manage to get what I wanted, and then I saw Œœ lol \$\endgroup\$ Commented Aug 7, 2019 at 14:21
7
\$\begingroup\$

JavaScript, 28 bytes

s=>s.every((x,y)=>x==s[y|1])

Try it online!


23 bytes using wastl's regex

s=>/^((.)2円)*$/.test(s)

Try it online!

answered Aug 6, 2019 at 16:49
\$\endgroup\$
3
  • \$\begingroup\$ 24 bytes, but outputs an array for true, null for false: Try it online! \$\endgroup\$ Commented Aug 6, 2019 at 16:52
  • \$\begingroup\$ 27 bytes s=>!s.some((x,y)=>x>s[y|1]) \$\endgroup\$ Commented Aug 7, 2019 at 5:51
  • \$\begingroup\$ @tsh Unfortunately, that would only work if you replaced > with != \$\endgroup\$ Commented Aug 7, 2019 at 15:48
7
\$\begingroup\$

x86 machine code, (削除) 9 (削除ここまで) 8 bytes

D1 E9 SHR CX, 1 ; divide length in half
 L1:
AD LODSW ; load next two chars into AH/AL 
3A E0 CMP AH, AL ; compare AH and AL 
E1 FB LOOPE L1 ; if equal, continue loop
C3 RET ; return to caller

Callable function. Input string in SI, input string length in CX. Output ZF if is double speak.

Or 14 bytes as a complete PC DOS executable:

B4 01 MOV AH, 01H ; DOS read char from STDIN (with echo) 
CD 21 INT 21H ; read first char into AL
92 XCHG DX, AX ; put first char into DL
B4 08 MOV AH, 08H ; DOS read char from STDIN (no echo) 
CD 21 INT 21H ; read second char into AL
3A C2 CMP AL, DL ; compare first and second char 
74 F3 JE -13 ; if the same, continue loop 
C3 RET ; otherwise exit to DOS 

Input is via STDIN, either pipe or interactive. Will echo the "de-doubled" input until a non-doubled character is detected, at which point will exit (maybe bending I/O rules a little bit, but this is just a bonus answer).

enter image description here

Build and test ISDBL2.COM using xxd -r:

00000000: b401 cd21 92b4 08cd 213a c274 f3c3 ...!....!:.t..

Original 24 bytes complete PC DOS executable:

D1 EE SHR SI, 1 ; SI to DOS PSP (080H) 
AD LODSW ; load string length into AL 
D0 E8 SHR AL, 1 ; divide length in half 
8A C8 MOV CL, AL ; put string length into BL 
 CLOOP: 
AD LODSW ; load next two chars into AH/AL 
3A E0 CMP AH, AL ; compare AH and AL 
E1 FB LOOPE CLOOP ; if equal, continue loop
 DONE: 
B8 0E59 MOV AX, 0E59H ; BIOS tty function in AH, 'Y' in AL 
74 02 JZ DISP ; if ZF, result was valid double 
B0 4E MOV AL, 'N' ; if not, change output char to N 
 DISP: 
B4 0E MOV AH, 0EH 
CD 10 INT 10H 
C3 RET ; return to DOS

Input from command line, output to screen 'Y' if double, 'N' if not.

enter image description here

Build and test ISDBL.COM using xxd -r:

00000000: d1ee add0 e88a c8ad 3ae0 e1fb b859 0e74 ........:....Y.t
00000010: 02b0 4eb4 0ecd 10c3 ..N.....

Credits:

  • -2 bytes thx to @ErikF!
answered Aug 7, 2019 at 14:34
\$\endgroup\$
2
  • 2
    \$\begingroup\$ Suggest using LOOPE instead of JNZ/LOOP to save 2 bytes. \$\endgroup\$ Commented Aug 7, 2019 at 16:11
  • \$\begingroup\$ @ErikF, brilliant! Completely forgot about that! \$\endgroup\$ Commented Aug 7, 2019 at 16:17
7
\$\begingroup\$

Malbolge (unlimited memory access variant), Around 4 megabytes

You asked the golfers, but for the second time forgot about the bowlers.

This is too big to include in the answer for obvious reason so here is gist link.

You might want to use the fast interpreter to test this program, as it's hellishly slow (hellishly, get it?). I'm going to include the TIO.run link after Dennis (hopefully) takes on my issue on TIO tracker.

// Edit: Nope, no TIO link as the answer size limit is 65536 bytes, and no abusing url shorteners because they just refuse to shorten it

answered Aug 11, 2019 at 16:57
\$\endgroup\$
1
  • \$\begingroup\$ what is this monstrosity :) \$\endgroup\$ Commented Aug 13, 2019 at 16:45
6
\$\begingroup\$

PHP, (削除) 58 (削除ここまで) 56 bytes

function f($s){return!$s?:$s[0]==$s[1]&f(substr($s,2));}

Try it online!

As a recursive function.

PHP, (削除) 61 (削除ここまで) (削除) 56 (削除ここまで) 52 bytes

while(''<$l=$argn[$i++])$r|=$l!=$argn[$i++];echo!$r;

Try it online!

Or standalone program. Input string via STDIN, output is truthy (1) if it is double speak, and falsey (0) if it is not double speak.

-4 bytes thx to @Night2!

answered Aug 6, 2019 at 15:49
\$\endgroup\$
2
  • 1
    \$\begingroup\$ This appears to output 1 for a non-double speak string, as well as a double speak string. \$\endgroup\$ Commented Aug 6, 2019 at 16:01
  • \$\begingroup\$ @AJFaraday try now - is double speak, is not double speak \$\endgroup\$ Commented Aug 6, 2019 at 16:07
6
\$\begingroup\$

Haskell, (削除) 28 (削除ここまで) 23 bytes

f(x:y:z)|x==y=f z
f[]=1

Try it online!

Very straightforward. Double speak is only empty or a repeated character prepended to double speak.

Less straightforward now. Outputs via presence or absence of an error, per meta consensus; no error means double speak. Pattern matching fails when the first two characters differ or when there are an odd number of characters. Thanks to Laikoni for these savings!

answered Aug 6, 2019 at 19:08
\$\endgroup\$
0
6
\$\begingroup\$

Lua, (削除) 67 (削除ここまで) (削除) 66 (削除ここまで) (削除) 63 (削除ここまで) (削除) 59 (削除ここまで) (削除) 33 (削除ここまで) 32 bytes

-25 bytes thanks to Giuseppe
-1 byte thanks to val

print(#(...):gsub("(.)%1","")<1)

Try it online!

Removes every doubled character, then checks if the result is empty.

answered Aug 7, 2019 at 16:19
\$\endgroup\$
7
  • 1
    \$\begingroup\$ why not just i:gsub("(.)%1","") and check if i==""? \$\endgroup\$ Commented Aug 8, 2019 at 16:26
  • 1
    \$\begingroup\$ this is 34 bytes, not totally sure it's valid since I've never written Lua before, but it appears to work. \$\endgroup\$ Commented Aug 8, 2019 at 16:27
  • \$\begingroup\$ welcome to Code Golf Stack Exchange though! \$\endgroup\$ Commented Aug 8, 2019 at 16:28
  • \$\begingroup\$ I assumed that "(.)%1" by itself included collisions, but it didn't occur to me that by replacing it once for all captures would be enough. Should I implement your solution or should you write your own answer? And thanks! \$\endgroup\$ Commented Aug 8, 2019 at 17:03
  • 1
    \$\begingroup\$ Nice idea! arg[1] can be replaced with (...) to save one byte. \$\endgroup\$ Commented Aug 12, 2019 at 10:44
5
\$\begingroup\$

Perl 5, 15 bytes

$_=/^((.)2円)*$/

Try it online!

Outputs 1 for double-speak, nothing for non-double-speak.

answered Aug 6, 2019 at 16:49
\$\endgroup\$
5
\$\begingroup\$

MathGolf, 2 bytes

1⁄2=

Try it online!

Basically the same as the 05AB1E answer, 1⁄2 splits the string into even and odd characters, then check for equality. Passes for the empty string.

answered Aug 6, 2019 at 16:51
\$\endgroup\$
5
\$\begingroup\$

PowerShell, (削除) 39 (削除ここまで) 38 bytes

!$($args|?{+$p*($p="$_"[$p-eq$_])};$p)

Try it online!

where $p contains a previous char.

No recursion, no regex :). Takes input as a char-array via a splatting string (see TIO link).


PowerShell, 48 bytes

for(;$b-eq$a-and$args){$a,$b,$args=$args}$b-eq$a

Try it online!

No recursion, no regex and no pipe :D. It also takes input as a char-array via a splatting string. It uses $b-eq$a instead $a-eq$b for a case when a last char has #0 code.

answered Aug 7, 2019 at 5:31
\$\endgroup\$
5
\$\begingroup\$

Shakespeare Programming Language, (削除) 204 (削除ここまで) 156 bytes

-48 bytes thanks to Jo King (mostly by changing the output method)

A.Ajax,.Puck,.Act I:.Scene I:.[Exeunt][Enter Ajax and Puck]Ajax:Open mind.Puck:Open
mind.Is I worse zero?If soSpeak thy.Is you as big as I?If soLet usAct I.

Try it online!

Exits with error if the input is double speak, and with warning if it is not double speak (which is allowed by default).

answered Aug 11, 2019 at 22:18
\$\endgroup\$
0
5
\$\begingroup\$

Keg, (削除) 19 (削除ここまで) 17 characters

?{!1<|=[|0.(_)]}1

Explanation:

? # read input
{ # while
 !1< # stack length greater than 1?
| # end of while condition and beginning of while block
 = # compare the 2 top values in the stack
 [ # if (the condition is the top of stack)
 | # end of then block and beginning of else block
 0. # output 0
 (_) # clear stack (discard top of stack in for loop stack length times)
 ] # end if
} # end while
1 # stack is already empty, push a truthy value
 # implicitly output the stack content if there was no explicit output

Try it online!

answered Aug 20, 2019 at 11:28
\$\endgroup\$
4
  • \$\begingroup\$ The < should be a > \$\endgroup\$ Commented Jan 14, 2020 at 3:53
  • \$\begingroup\$ And, uh, 10 bytes with -rR flag \$\endgroup\$ Commented Jan 14, 2020 at 3:56
  • \$\begingroup\$ 6 bytes with -rR flag \$\endgroup\$ Commented Jan 14, 2020 at 3:58
  • \$\begingroup\$ For the sake of it, 5 bytes using -ir, -lp and -rR \$\endgroup\$ Commented Jan 14, 2020 at 4:01
5
+50
\$\begingroup\$

Husk, (削除) 6 (削除ここまで) 4 bytes

-2 bytes thanks to Razetime!

ETC2

Try it online!

Hooray for all ASCII solutions! Outputs a positive number if the input is doublespeak, otherwise zero.

 C2 Cut list into chunks of 2
 T Transpose
E Check if list has all the same elements (return length of list if so)
answered Oct 2, 2020 at 17:52
\$\endgroup\$
3
  • \$\begingroup\$ -2 \$\endgroup\$ Commented Feb 19, 2021 at 6:58
  • \$\begingroup\$ @Razetime That doesn't appear to check if the length is even \$\endgroup\$ Commented Feb 19, 2021 at 7:11
  • 3
    \$\begingroup\$ this should work \$\endgroup\$ Commented Feb 19, 2021 at 7:12
5
\$\begingroup\$

Vyxal, 2 bytes

y=

Try it Online!

Look ma, no Unicode!

answered Jul 14, 2021 at 0:23
\$\endgroup\$
4
\$\begingroup\$

V (vim), 7 bytes

Óˆ±
ø^$

Try it online! or Verify test cases

Hexdump:

00000000: d388 b10a d85e 24 .....^$

Just two regexes. Explanation:

Ó " Remove all occurrences...
 ˆ " Any character
 ± " Followed by itself
 " This regex is actually just the compressed form of (.)1円
ø " Count the number of matches
 ^$ " An empty line
answered Aug 6, 2019 at 15:54
\$\endgroup\$
4
\$\begingroup\$

Brachylog, 5 bytes

ġ2z2=

Try it online!

Succeeds or fails.

ġ2 The at-most-length-2 chunks of the input,
 z2 which have equal length, zipped together,
 = are equal.
answered Aug 6, 2019 at 20:15
\$\endgroup\$
4
\$\begingroup\$

INTERCAL, 192 bytes

PLEASE,1<-#2DOCOMEFROM(2)DOWRITEIN,1DO.5<-#1$',1SUB#1'~#256PLEASE(1)NEXTDOREADOUT#1DOGIVEUP(1)DO(1002)NEXTDO.5<-#1$',1SUB#2'~,1SUB#2DO(3)NEXTDOREADOUT#0PLEASEGIVEUP(3)DO(1002)NEXT(2)DOFORGET#2

Try it online!

Output is done with INTERCAL's native "butchered Roman numerals", so the true output of 1 prints as \nI\n, and the false output of 0 prints as _\n\n.

I don't feel like writing out a full explanation at the moment, but the ungolfed code is here, I lifted the control flow from something I wrote earlier, and the gist of what it does is read two characters at a time from the input through the usually unhelpful "Turing Tape" I/O until either the first resulting number is 256 (in which case the entire input has been validated and has even length, so it is double-speak), or the second resulting number is not 0 (in which case the second character is different from the first or does not exist, and the input is not double-speak).

I think I might be able to restructure this to cut down on redundancy, but I'm not quite feeling up to that at the moment either.

answered Aug 7, 2019 at 6:11
\$\endgroup\$
4
\$\begingroup\$

PowerShell, (削除) 64 (削除ここまで) 59 bytes

filter f($n){$a,$b,$r=$n;$a-eq$b-and$(if($r){f $r}else{1})}

Try it online!

Recursive function, no regex. Takes input as a char-array (see TIO link). Peels off the first two elements into $a and $b, stores the remaining into $r. If we still have elements remaining, recurse along with $a -eq $b. Otherwise just check whether $a -eq $b. Output is implicit.

-5 bytes thanks to mazzy

answered Aug 6, 2019 at 19:48
\$\endgroup\$
2
  • 1
    \$\begingroup\$ de-duplicate Try it online! \$\endgroup\$ Commented Aug 7, 2019 at 4:19
  • 1
    \$\begingroup\$ @mazzy Thanks! I was missing the $ before the statement block and couldn't figure out why it wasn't working. \$\endgroup\$ Commented Aug 7, 2019 at 12:37
4
\$\begingroup\$

Julia 1.0, 25 bytes

s->s[1:2:end]==s[2:2:end]

Try it online!

answered Aug 6, 2019 at 15:50
\$\endgroup\$
2
  • 3
    \$\begingroup\$ It's shorter to use a symbol instead of f, e.g !a=.... Or to use an anonymous function: s->... \$\endgroup\$ Commented Aug 6, 2019 at 15:54
  • \$\begingroup\$ Yes, you're right. I fixed it \$\endgroup\$ Commented Aug 7, 2019 at 15:15
4
\$\begingroup\$

J, (削除) 13 (削除ここまで) (削除) 11 (削除ここまで) 10 bytes

-:2#_2{.\]

Try it online!

-2 bytes thanks to Adám

-1 byte thanks to miles

TLDR explanation: Is the input the same as every other character of the input doubled?

answered Aug 6, 2019 at 18:13
\$\endgroup\$
3
  • \$\begingroup\$ -:]#~2 0$~# \$\endgroup\$ Commented Aug 6, 2019 at 19:03
  • \$\begingroup\$ -:2#_2{.\] should save another byte \$\endgroup\$ Commented Aug 7, 2019 at 22:51
  • \$\begingroup\$ very nice, thanks @miles \$\endgroup\$ Commented Aug 7, 2019 at 22:56
4
\$\begingroup\$

Curry, 18 bytes

Tested to work in both PAKCS and KiCS2

f(a:a:x)=f x
f[]=1

Try it online!

Test it on smap!

This returns 1 if string is double speak and nothing otherwise.

Explanation

This is a pretty straight forward translation of the Haskell program:

f(a:b:x)|a==b=f x
f[]=1

But it uses Curry's more powerful pattern matches to save a bunch of bytes. And while missing a pattern in Haskell is rather difficult to recover from, making this definitely pretty un-idiomatic at best and perhaps a little cheaty. In curry missing patterns just mean it's not a match which is idiomatic and recoverable. So it's shorter and I don't feel like I'm cheating.

Testing

TIO has a limited ability to test things like this. I recommend you use the smap link to test this. This test handler I've made on smap will not work in KiCS2 or the newer version of PAKCS so you must select PAKCS 2.2.0 (both /one-value and /all-values work fine). This is because of the library Control.SetFunctions which I use for the test. But the function itself does work in the versions if you want to manually test it.

answered Apr 6, 2022 at 15:55
\$\endgroup\$
4
\$\begingroup\$

Vyxal, 14 bitsv2 , 1.75 bytes

y=

Try it Online!

Basically every other answer

Explained

y=
y # Uninterleave the input, dumping to stack
 = # Are the two items equal?
answered Jul 3, 2023 at 4:40
\$\endgroup\$
4
\$\begingroup\$

Wolfram Language (Mathematica), (削除) 27 (削除ここまで) (削除) 26 (削除ここまで) (削除) 24 (削除ここまで) 22 bytes

1##&@@@-1^Split@#0&

Try it online!

Input a list of characters. is \[VectorGreater].

 Split@# runs
1##&@@@-1^ (-1)^lengths(runs)
 0 all>0
answered Aug 7, 2019 at 1:51
\$\endgroup\$
2
  • \$\begingroup\$ You've excluded the necessary code to convert the string input into a list which can be fed to Split (i.e. the 11 bytes of Characters@) \$\endgroup\$ Commented Aug 7, 2019 at 17:14
  • 2
    \$\begingroup\$ @AntiEarth What's a string? \$\endgroup\$ Commented Aug 7, 2019 at 19:30
1
2 3 4

Your Answer

Draft saved
Draft discarded

Sign up or log in

Sign up using Google
Sign up using Email and Password

Post as a guest

Required, but never shown

Post as a guest

Required, but never shown

By clicking "Post Your Answer", you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.