StringgnirtSStringgnirtSStringgnirtS

44

6

Here is a relatively simple challenge for you.

Given a string of length N, output the string forwards, then backwards, then forwards, then backwards... etc. N times. For example, if your input was

Hello!

You should output:

Hello!!olleHHello!!olleHHello!!olleH

You may also optionally output one trailing newline.

Your submission may be either a full program or a function, and you may take input and output in any reasonable format. For example, you may take IO from STDIN/STDOUT, function arguments and return value, from a file, etc. You can safely assume that the input string will not be empty, and will only contain printable ASCII. You must output the new string on a single line. So, for example, if the output to the last example was

Hello!
!olleH
Hello!
!olleH
Hello!
!olleH

This would not be a valid solution!

Here are some more test cases:

Input:
a
Output:
a

Input:
abcd
Output:
abcddcbaabcddcba

Input:
OK!
Output:
OK!!KOOK!

Input:
4815162342
Output:
4815162342243261518448151623422432615184481516234224326151844815162342243261518448151623422432615184

Input:
PPCG
Output:
PPCGGCPPPPCGGCPP

Input:
42
Output:
4224

Leaderboards

Since this is a challenge, standard loopholes are banned, and the shortest answer in bytes wins! However, this is also a competition to have the shortest answer in any particular langauge. While it's unlikely that a Java answer will beat an answer in perl, or some golfing language, it's still very impressive to have the shortest Java answer. So, you can use this leaderboard to see both

  1. The shortest answer out of all languages, and

  2. The shortest answer in each individual language.

To make sure that your answer shows up, please start your answer with a headline, using the following Markdown template:

# Language Name, N bytes

where N is the size of your submission. If you improve your score, you can keep old scores in the headline, by striking them through. For instance:

# Ruby, <s>104</s> <s>101</s> 96 bytes

If there you want to include multiple numbers in your header (e.g. because your score is the sum of two files or you want to list interpreter flag penalties separately), make sure that the actual score is the last number in the header:

# Perl, 43 + 2 (-p flag) = 45 bytes

You can also make the language name a link which will then show up in the leaderboard snippet:

# [><>](http://esolangs.org/wiki/Fish), 121 bytes

var QUESTION_ID=93261,OVERRIDE_USER=31716;function answersUrl(e){return"https://api.stackexchange.com/2.2/questions/"+QUESTION_ID+"/answers?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+ANSWER_FILTER}function commentUrl(e,s){return"https://api.stackexchange.com/2.2/answers/"+s.join(";")+"/comments?page="+e+"&pagesize=100&order=desc&sort=creation&site=codegolf&filter="+COMMENT_FILTER}function getAnswers(){jQuery.ajax({url:answersUrl(answer_page++),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){answers.push.apply(answers,e.items),answers_hash=[],answer_ids=[],e.items.forEach(function(e){e.comments=[];var s=+e.share_link.match(/\d+/);answer_ids.push(s),answers_hash[s]=e}),e.has_more||(more_answers=!1),comment_page=1,getComments()}})}function getComments(){jQuery.ajax({url:commentUrl(comment_page++,answer_ids),method:"get",dataType:"jsonp",crossDomain:!0,success:function(e){e.items.forEach(function(e){e.owner.user_id===OVERRIDE_USER&&answers_hash[e.post_id].comments.push(e)}),e.has_more?getComments():more_answers?getAnswers():process()}})}function getAuthorName(e){return e.owner.display_name}function process(){var e=[];answers.forEach(function(s){var r=s.body;s.comments.forEach(function(e){OVERRIDE_REG.test(e.body)&&(r="<h1>"+e.body.replace(OVERRIDE_REG,"")+"</h1>")});var a=r.match(SCORE_REG);a&&e.push({user:getAuthorName(s),size:+a[2],language:a[1],link:s.share_link})}),e.sort(function(e,s){var r=e.size,a=s.size;return r-a});var s={},r=1,a=null,n=1;e.forEach(function(e){e.size!=a&&(n=r),a=e.size,++r;var t=jQuery("#answer-template").html();t=t.replace("{{PLACE}}",n+".").replace("{{NAME}}",e.user).replace("{{LANGUAGE}}",e.language).replace("{{SIZE}}",e.size).replace("{{LINK}}",e.link),t=jQuery(t),jQuery("#answers").append(t);var o=e.language;/<a/.test(o)&&(o=jQuery(o).text()),s[o]=s[o]||{lang:e.language,user:e.user,size:e.size,link:e.link}});var t=[];for(var o in s)s.hasOwnProperty(o)&&t.push(s[o]);t.sort(function(e,s){return e.lang>s.lang?1:e.lang<s.lang?-1:0});for(var c=0;c<t.length;++c){var i=jQuery("#language-template").html(),o=t[c];i=i.replace("{{LANGUAGE}}",o.lang).replace("{{NAME}}",o.user).replace("{{SIZE}}",o.size).replace("{{LINK}}",o.link),i=jQuery(i),jQuery("#languages").append(i)}}var ANSWER_FILTER="!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe",COMMENT_FILTER="!)Q2B_A2kjfAiU78X(md6BoYk",answers=[],answers_hash,answer_ids,answer_page=1,more_answers=!0,comment_page;getAnswers();var SCORE_REG=/<h\d>\s*([^\n,]*[^\s,]),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/,OVERRIDE_REG=/^Override\s*header:\s*/i;
body{text-align:left!important}#answer-list,#language-list{padding:10px;width:290px;float:left}table thead{font-weight:700}table td{padding:5px}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr></thead> <tbody id="answers"> </tbody> </table> </div><div id="language-list"> <h2>Winners by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr></thead> <tbody id="languages"> </tbody> </table> </div><table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr></tbody> </table>

James

Posted 2016-09-15T03:00:42.067

Reputation: 54 537

In your example, shouldn't that be olleH, not elloH ? – Arnaud – 2016-09-15T03:27:51.250

@SuperChafouin Haha, you're right. I've fixed that now. – James – 2016-09-15T03:31:13.500

@DJMcMayhem can we take the input reversed? Or output the reversed letters in the oppsite order? e.g. !olleHHello! kinda thing – Downgoat – 2016-09-15T03:52:05.437

2@Downgoat No, you must take input and output in the same format as the spec describes. – James – 2016-09-15T04:15:25.630

4Shouldn't the title be StringgnirtSStringgnirtSStringgnirtS? – Luis Mendo – 2016-09-15T08:39:49.293

What if the input has a newline? "\nHello!\n\n" – Magic Octopus Urn – 2016-09-15T12:29:39.177

2@carusocomputing It won't: "You can safely assume that the input string will not be empty, and will only contain printable ASCII." – Martin Ender – 2016-09-15T13:50:47.267

1https://en.wikipedia.org/wiki/ASCII#Printable_characters Ah, didn't know that was a well defined subset of ASCII. I imagined printable to include \t, \n, etc... – Magic Octopus Urn – 2016-09-15T14:59:52.430

LOL'ing at OK!!KOOK! – dkudriavtsev – 2016-09-16T23:47:57.767

Answers

23

Vim, 39, 34 keystrokes

:se ri
Y:s/./<C-r>"/g
<C-o>qqgJC<C-r>"<esc>gJ@qq@q

5 bytes saved thanks to @Lynn!

Here is a gif of it happening live: (Note that this gif is of a previous version since I haven't had time to re-record it yet).

enter image description here

And here is an explanation of how it works:

:se ri                  "Turn 'reverse indent' on.
Y                       "Yank this line
:s/./<C-r>"/g           "Replace every character on this line with the register
                        "We just yanked followed by a newline
<C-o>                   "Jump to our previous location
     qq                 "Start recording in register 'q'
       gJ               "Join these two lines
         C              "Delete this line, and enter insert mode
          <C-r>"<esc>   "Paste the line we just deleted backwards 
gJ                      "Join these two lines
  @q                    "Call macro 'q'. This will run until we hit the bottom of the buffer.
    q                   "Stop recording.
     @q                 "Start our recursive macro

On a side note, Y grabs an extra newline, which is usually an obnoxious feature. This is probably the first ever time that it has actually saved several bytes!

James

Posted 2016-09-15T03:00:42.067

Reputation: 54 537

2Instead of :%s/\n<cr>, you can do v{gJ to save three bytes. – Lynn – 2016-09-15T08:45:37.217

2A VIM answer?! That's a classy move on your part. – Magic Octopus Urn – 2016-09-15T12:31:07.410

@Lynn Thanks for the tip! I ended up doing something slightly different and took 5 off instead. – James – 2016-09-15T20:10:38.533

This assumes that @q is empty at the start, right? or the @q before stopping recording would do something arbitrary. (This leads me to my favorite vim trivium that I've come up with: everyone knows that quitting vim is as easy as :q<CR>, but how do you close and save all your files? easy: just qqqqqZZ@qq@q!) – wchargin – 2016-09-17T23:24:12.613

@wchargin Yes, this does require @q to be empty. Why not just do :wqa instead? Also wanna know how to generate a fractal in vim? qqqqq<C-w>v<C-w>n@qq@q :D – James – 2016-09-17T23:43:39.587

@DJMcMayhem "why not just do :wqa instead?" …because it's a joke? – wchargin – 2016-09-18T12:21:04.607

Nooo! You answered before me and your answer is much better than mine!I'm voting you up and go pout in a corner. – Christian Rondeau – 2016-09-20T18:47:39.007

@ChristianRondeau Hahaha, thanks! Mine isn't even the shortest vim answer though.

– James – 2016-09-20T18:49:21.787

19

Python, 40 bytes

f=lambda s,i=0:s[i:]and s+f(s[::-1],i+1)

A recursive function. Prepends the input string s to the function of the reverse until the counter i exceed the length of s.

xnor

Posted 2016-09-15T03:00:42.067

Reputation: 115 687

Wow. I was just about to submit a 56 byte python answer, haha – James – 2016-09-15T03:15:14.830

@DJMcMayhem it also beats lambda s:(len(s)*(s+s[::-1]))[:len(s)**2] by one byte. – Jonathan Allan – 2016-09-15T06:01:25.760

I've gotten this f = lambda s : ''.join([s[((-1)**(i//len(s)) <= 0)*(len(s)-1)+(-1)**(i//len(s))*(i%len(s))] for i in range(len(s)*len(s))]) but it's 136 bytes according to sys.sizeof, interestingly it's the same size as f = lambda s : ''.join([s[::1] if i%2 else s for i in range(len(s))]) – Carel – 2016-09-18T19:39:09.083

13

Brain-Flak, 418 378 228 bytes

This is my Brain-Flak masterpiece. It may not be well golfed but the challenge is the most difficult I have ever encountered.

Try it online!

(([])[()]){({}[()]<(({}(<()>))<{({}[()]<(({}()<(({}<>))>)<({()<({}[()]<({}<({}<>)<>>)>)>}{}<>){({}[()]<({}<>)<>>)}{}>)>)}{}{}<>([]){{}({}<>)<>([])}{}<>>)>)}{}([(({}))]{({})({}[()])}{}){(({}[({}<>)<>])<<>({}<><{(({}[()])<{({}[()]<({}<({}<>)<>>)>)}{}<>([]){{}({}<>)<>([])}{}<>>)}{}>)>)}

Explanation

This explanation is now a bit outdated but it still does a pretty good job of explaining the program.

This explanation is going to go a little different from my regular explanation process. I am going to explain how I came about this result rather than explain the result in order. Here it goes:

Roller

After working at the problem a quite a bit I came up with this code:

(n[()])({()<({}[()]<({}<({}<>)<>>)>)>}{}<>){({}[()]<({}<>)<>>)}{}<>

This code (where n is the literal for some number. e.g. ()()) will take the item on the top of the stack and move it down n steps. With n as the stack height this will perform a stack "roll". i.e. move the top item to the bottom of the stack. Here's how it works:

We put the place we want to move the item to minus one on the stack. Why minus one? I don't know it just works that way.

(n[()])

We then loop until this number reaches zero keeping track of the loop with a ().

{()<({}[()]<...>)>)>}{}

Each time we loop we pick up the top item and move the item underneath it to the other stack. This puts the number on top in its place.

({}<({}<>)<>>)

All we need to do now is put the numbers we moved back. We switch to the off stack and push the number of runs the loop made.

(...<>)

We loop decrementing the newly pushed number until it reaches zero. Each time we move one number back.

{({}[()]<({}<>)<>>)}{}<>

Reverse

I next modified the roll to make a full stack reverse:

(n){(({}[()])<{({}[()]<({}<({}<>)<>>)>)}{}<>([]){{}({}<>)<>([])}{}<>>)}{}

Once again n represents the depth of the reverse. That is the top n items on the stack will be reversed. How it works:

The reverse is just a fancily wrapped roller. We simply roll the top of the stack n times decrementing the depth of the roll by one each time.

(n){(({}[()])<ROLLER>)}{}

Duplicate

In place duplication is hard. Really hard. After I figured out how to reverse the stack it still took a great deal of effort to come up with the duplication algorithm.

Here it is:

(((n)<{({}[()]<(({}<>))<>>)}{}<>>)<{({}[()]<({}<>)<>([][()])({()<({}[()]<({}<({}<>)<>>)>)>}{}<>){({}[()]<({}<>)<>>)}{}<>>)}{}<>([]){{}({}<>)<>([])}{}<>([]){(({}[()])<{({}[()]<({}<({}<>)<>>)>)}{}<>([]){{}({}<>)<>([])}{}<>>)}{}>)

Its a bit of a big one but here's how it works:

Start by pushing n. n is the depth of the duplicate. We also open two parentheses. These allow us to store the value of the n in the scope until its needed again.

(((n)<

Next we loop n times each time pushing the top value of the stack to the off stack twice. This makes the initial duplicates for each number on the stack.

{({}[()]<(({}<>))<>>)}{}

Now we have two copies of each number on the offstack. We need to separate these into two groups.

So we switch to the offstack and recall one of the ns we saved at the beginning.

<>>)

We loop n times.

{({}[()]<...>)}{}

Each time we move one copy to the mainstack.

({}<>)<>

And roll one copy to the bottom of the stack. (This assumes the offstack was empty to begin with making this duplicate not stack clean)

([][()])ROLLER

Once that is done we have split the original into two groups the "original" and a copy on the offstack (the copy is actually in reverse). So we just move the copy to the main stack and we can be done with it.

([]){{}({}<>)<>([])}{}<>

Skeleton program

Now that I have made all of the pieces of the program, I just have to insert them into a frame.

The frame doubles the text one less than the stack's height times Using duplicate.

(([])[()])
{
 ({}[()]<
  DUPLICATE 
 >)
>)}{}

And then reverses the stack in decreasing increments of the initial stack height from n^2-n to 0.

(({}))
{
 (({}[()])<
  ({}<>)<>(({}))({<({}[()])><>({})<>}{})<>{}<>
  ({}<({}<>)<>>)<>({}<>)
  ({}<
   REVERSE
  >)
 >)
}{}{}

Post Rock Garf Hunter

Posted 2016-09-15T03:00:42.067

Reputation: 55 382

5Amazing. You always blow my mind with what this language can do! :D – James – 2016-09-15T06:26:18.853

11

Jelly, 4 3 bytes

,Ṛṁ

Try it online! or Verify all test cases.

Saved a byte thanks to @Maltysen.

Explanation

,Ṛṁ  Input: string S
 Ṛ    Reverse S
,     Join S with reverse of S. Makes a list [S, rev(S)]
  ṁ   Mold [S, rev(S)] to len(S) by repeating elements cyclically
      Return and print implicitly as a string

miles

Posted 2016-09-15T03:00:42.067

Reputation: 15 654

1mold doesn't need the L – Maltysen – 2016-09-15T03:35:04.813

@Maltysen wow thanks, did you know that from the source code or from experience – miles – 2016-09-15T03:36:22.313

from experience, I don't know Jelly, but I kinda guessed that's what mold would do on a non-number, since Jelly doesn't really do overloads, also mold kinda reminded me of reshape from J – Maltysen – 2016-09-15T03:39:12.183

mold actually takes only iterables, but it casts integers to range first. – Dennis – 2016-09-15T03:39:16.573

1Yeah I treated mold as reshape so I just habitually gave it a number. There's so many neat little treats in Jelly, like how an array of strings is just automatically output as a concatenated string – miles – 2016-09-15T03:41:22.773

10

2sable, 3 bytes

Code:

gGÂ

Explanation:

g   # Get the length of the input
 G  # Do the following n - 1 times:
  Â # Bifurcate, which duplicates a and reverses the duplicate

Uses the CP-1252 encoding. Try it online!

Adnan

Posted 2016-09-15T03:00:42.067

Reputation: 41 965

10

PHP, 54 52 bytes

(49 bytes, but do not work if string contains '0')

for(;($a=$argv[1])[$i++];)echo$i%2?$a:strrev($a);

(52 bytes)

<?=str_pad('',strlen($a=$argv[1])**2,$a.strrev($a));

(54 bytes)

for(;$i++<strlen($a=$argv[1]);)echo$i%2?$a:strrev($a);

Crypto

Posted 2016-09-15T03:00:42.067

Reputation: 862

I completely forgot about str_pad. nice one! – Titus – 2016-09-15T07:23:42.840

8

J, 13 8 bytes

Saved 5 bytes thanks to miles!

#;@$];|.

This is a 5-train with the following verbs:

# ;@$ ] ; |.

The inner fork is composed of ] (identity), ; (link), and |. (reverse). Observe:

   (| ; |.) 'Hello!'
+------+------+
|Hello!|!olleH|
+------+------+

The outer two verbs make the rest of the train. # is, in this case, the size of the argument, that is, the length. The verb linking these is ;@$, or ravel over reshape. Observe:

   # 'Hello!'
6
   6 $ (] ; |.) 'Hello!'
+------+------+------+------+------+------+
|Hello!|!olleH|Hello!|!olleH|Hello!|!olleH|
+------+------+------+------+------+------+
   ; 6 $ (] ; |.) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH
   6 ;@$ (] ; |.) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH
   (# ;@$ (] ; |.)) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH
   (# ;@$ ] ; |.) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH
   (#;@$];|.) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH

Old solution.

[:,|.^:(i.@#)

Simple enough. |. is reverse, and ^: is power conjunction, which repeats it's left verb (right hand) # of times. When the right argument is a verb, that verb is called on the argument. The right verb in this case is range from zero (i.) to the length (#). When raised to an array, the intermediate results are kept. All that needs to be done is to flatten the array with ,.

Intermediate results

   (i.@#) 'Hello!'
0 1 2 3 4 5
   |.^:0 1 2 3 4 5 'Hello!'
Hello!
!olleH
Hello!
!olleH
Hello!
!olleH
   |.^:(i.@#) 'Hello!'
Hello!
!olleH
Hello!
!olleH
Hello!
!olleH
   ([:,|.^:(i.@#)) 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH

Conor O'Brien

Posted 2016-09-15T03:00:42.067

Reputation: 36 228

You can save a byte by boxing the length <@# – miles – 2016-09-15T03:25:55.723

A neat 8 byte solution is #;@$];|. which boxes the initial and reverse, reshapes the boxed strings and razes them together – miles – 2016-09-15T03:42:41.617

@miles whoa, that's pretty neat. – Conor O'Brien – 2016-09-15T11:09:02.870

7

Ruby, 39 bytes

->(s){s.reverse!.gsub(/./){s.reverse!}}

I suck at Ruby. Golfing help is appreciated.

Ruby is a really nice language for this because of .reverse!

Explanation

I was hoping it would be someting simple like:

s.gsub(/./){s.reverse!}

but because of boilerplate/challenge restriction it's longer.

What s.reverse! is very useful. s.reverse! is basically s = s.reverse!, meaning it also mutates s.


What each section of the program does is described below:

->(s){             # Lambda with argument s
      s.reverse!   # Reverse `s` see above for details
      .gsub(/./)   # Replace every character with...
      {s.reverse!} # the input reversed!

The thing about s.reverse! that is great is that everytime it is evaluated the string get's flipped. So as it replaces the string. s is modified!

Downgoat

Posted 2016-09-15T03:00:42.067

Reputation: 27 116

With the -p flag you can save 4 bytes: $_.reverse!;gsub(/./){$_.reverse!} – Jordan – 2016-09-15T03:35:16.840

@Jordan would't I need a .chomp though on the $_? it seems to include the newline at the moment – Downgoat – 2016-09-15T03:47:52.187

Not if you do something like ruby -pe '$_.reverse!;gsub(/./){$_.reverse!}' < file.txt where file.txt is a line without the trailing newline :V Anyways, if you decide not to do that, you don't need parens on the lambda so ->s works – Value Ink – 2016-09-15T05:56:37.200

@ValueInk, you can provide newlineless input without file if you pipe it. Or you can even type it manually, just not press Enter: http://i.stack.imgur.com/6luxM.png

– manatwork – 2016-09-15T09:07:54.737

@Downgoat, as shorter alternative for .chomp there is the -l command-line switch, just like in Perl. – manatwork – 2016-09-15T09:09:13.397

@Downgoat Like they said. You can pipe in input without a newline (echo -n, which you see around here pretty regularly) or you can use the -l flag for +1 byte. – Jordan – 2016-09-15T12:52:00.583

1You don't need parentheses around the lambda's argument. Also, I think you can shave off one of the exclamation points: s.gsub(/./){s.reverse!.reverse} – m-chrzan – 2016-09-18T00:23:53.250

7

Perl, 24 bytes

Includes +2 for -lp

Give input on STDIN:

rev.pl <<< Hello!

rev.pl:

#!/usr/bin/perl -lp
s%.%s/.?/chop/eg;$`%eg

Surprisingly this does not use the builtin reverse operator. That name is just soooo long, all solutions I could think of with reverse are at least 1 byte longer.

Ton Hospel

Posted 2016-09-15T03:00:42.067

Reputation: 14 114

Upvoted for finding a solution that takes less bytes than a built-in – MilkyWay90 – 2019-03-17T22:24:07.913

6

JavaScript (ES 6), 59 50 bytes

9 Bytes thanks to Hedi and Huntro.

f=(s,n=1)=>s[n]?s+f([...s].reverse().join``,n+1):s

recursive function.

Reversing the string takes almost half of the size (25 22 bytes!) ...
Why isn´t there a native way for that?

Titus

Posted 2016-09-15T03:00:42.067

Reputation: 13 814

1You could use s[n]?... intead of n<s.length?... – Hedi – 2016-09-15T06:26:19.480

1You can also save 3 bytes by using [...s] instead of s.split\`` – Huntro – 2016-09-15T07:02:12.333

yea 36 bytes ideally f=(s,n=1)=>n==1?s:s+s.reverse(),n-1) – caub – 2016-09-15T13:52:35.063

non recursive one f=(s,n=1)=>Array.from({length:n},(_,i)=>i%2?s.reverse():s).join``) that would too be better with some better function for range – caub – 2016-09-15T13:58:45.290

@caub: SyntaxError: Unexpected token ) JS has no native string reversion. SyntaxError: Invalid or unexpected token for your second suggestion. What browser does that work in? – Titus – 2016-09-15T16:48:07.390

'ideally' String.prototype.reverse doesn't exist, it's just to show a better code, it doesn't work without modifying String's prototype – caub – 2016-09-15T19:16:09.480

also did you reject my edit? that's stupid, your current one doesn't work – caub – 2016-09-15T19:17:05.793

5

8088 Assembly, IBM PC DOS, 29 28 bytes

Assembled, xxd dump:

00000000: d1ee ac48 938a cbfc 518a cbf7 da78 01fd  ...H....Q....x..
00000010: acac b40e cd10 e2f9 59e2 ecc3            ........Y...

Unassembled listing:

D1 EE       SHR  SI, 1          ; point SI to DOS PSP (080H) 
AC          LODSB               ; load input string length into AL 
48          DEC  AX             ; remove leading space from length counter 
93          XCHG BX, AX         ; save input length to BL 
8A FB       MOV  BH, BL         ; string output counter in BH 
        S_LOOP: 
FC          CLD                 ; set direction forward 
8A CB       MOV  CL, BL         ; reset char counter in CL 
F7 DA       NEG  DX             ; flip DX to toggle fwd/back output 
78 01       JS   C_START        ; if positive, go forward 
FD          STD                 ; otherwise go backwards 
        C_START: 
AC          LODSB               ; adjust SI to first/last char
        C_LOOP: 
AC          LODSB               ; load next char into AL
B4 0E       MOV  AH, 0EH        ; PC BIOS tty output function
CD 10       INT  10H            ; write char to console
E2 F9       LOOP C_LOOP         ; continue looping through chars
FE CF       DEC  BH             ; decrement string count loop
75 EC       JNZ  S_LOOP         ; if not zero, continue loop
C3          RET                 ; exit to DOS

Standalone PC DOS executable program. Input string via command line, output is console.

enter image description here

640KB

Posted 2016-09-15T03:00:42.067

Reputation: 7 149

5

Minkolang, 17 bytes:

$oId$z$Dz[rz[O]].

Try it here!

Explanation

$o                   Read in whole input as characters
  Id                 Push the length of stack and duplicate
    $z               Pop top of stack and store in register (z)
      $D             Pop top of stack (n) and duplicate whole stack n-1 times
        z[     ]     z times, do the following:
          r          Reverse the stack
           z[O]      z times, pop the top of stack and output as character
                .    Stop.

El'endia Starman

Posted 2016-09-15T03:00:42.067

Reputation: 14 504

5

Haskell, 40 36 32 Bytes

m s=take(length s^2)$cycle$s++reverse s

Example:

*Main> m "Hello!"
"Hello!!olleHHello!!olleHHello!!olleH"

Even shorter (credit to Damien):

q s=zip(s>>[s,reverse s])s>>=fst

s>>[s,reverse s] cycles ["abc","cba",...] which is zipped to correct size and concatMap'ped with fst

michi7x7

Posted 2016-09-15T03:00:42.067

Reputation: 405

2q s=zip(s>>[s,reverse s])s>>=fst – Damien – 2016-09-15T11:23:31.250

3Or Pointfree one with same size: (>>=fst).(iterate reverse>>=zip) – Damien – 2016-09-15T11:33:21.443

4

Pip, 11 10 bytes

L#aORVRV:a

Try it online!

Explanation:

            a is first cmdline argument (implicit)
L#a         Loop len(a) times:
      RV:a   Reverse a and assign back to a
   ORV       Output the reverse of a (since it needs to go forward first then backward)

DLosc

Posted 2016-09-15T03:00:42.067

Reputation: 21 213

4

Perl 6,  31  30 bytes

{[~] (|($_,.flip)xx*)[^.chars]}

Save one byte by misusing .ords, which returns a list of ordinals, then implicitly turn that into a number to create a range with.

{[~] (|($_,.flip)xx*)[^.ords]}

Explanation:

# bare block lambda with implicit parameter 「$_」
{
  # reduce using string concatenation operator 「~」
  [~]

  (
    # create a Slip
    |(
      # of the input, and its string reverse
      $_, .flip

    # list repeated infinitely
    ) xx *

  # get the values in the range from 0 up-to and excluding
  # the number of characters 「0 ..^ +$_.ords」
  )[ ^.ords ]
}

Usage:

my &code = {[~] (|($_,.flip)xx*)[^.ords]}

say code 'a'; # a
say code 'abcd'; # abcddcbaabcddcba
say code 'OK!'; # OK!!KOOK!
say code 4815162342; # 4815162342243261518448151623422432615184481516234224326151844815162342243261518448151623422432615184

Brad Gilbert b2gills

Posted 2016-09-15T03:00:42.067

Reputation: 12 713

4

Vim + coreutils, 32 keystrokes

You can never have too many Vim answers.

qqYv:!rev
Pjq@=len(@")
@q2dkv{gJ

Explanation

qq               " Start recording macro
Y                " Yank (copy) line
v:!rev<CR>       " Reverse line with coreutils rev command
Pj               " Paste yanked line above this line
q                " Stop recording
@=len(@")<CR>@q  " Playback macro once for each character
2dk              " Delete last 3 lines
v{gJ             " Join lines

Jordan

Posted 2016-09-15T03:00:42.067

Reputation: 5 001

1With coreutils? That's cheating! :P – Christian Rondeau – 2016-09-20T19:42:44.400

4

MATL, 13 12 8 bytes

Pushes all elements, combines in the end.

td"tP]&h

td"  ]     %For loop over string length - 1 due to diff
   tP      %Push copy of string, reverse
      &h   %Concatenate entire stack horizontally

Try it online!


Old versions:

Completely different approach, based on fprintf:

t"t1$0#YDP]x

t"        ]   % For loop over string
  t           % Duplicate string for printing:
   1$0#YD     % `fprintf` with 1 input, 0 output (i.e., to screen).
         P    % Reverse
           x  % Empty stack to prevent implicit output

Version based on reversing a template string

ttd"wPtbYc]Dx

t                 %Duplicate input, to create 'accumulator' string 
                  % (alongside the input string which will serve as 'template'
 td               %Duplicate input, diff to get an stringof size input-1
   "       ]      %For loop over size n-1 string (consumes diff'd string)
     wP           %Get 'template' string on top of stack, and reverse
       tb         %Duplicate template string, and switch with 'accumulator' string
         Yc       %Concatenate template string with accumulator. 
            Dx   %Display top element, delete template string to prevent implicit disp

Sanchises

Posted 2016-09-15T03:00:42.067

Reputation: 8 530

I like the clever usage of td! – James – 2016-09-18T01:02:40.077

@DJMcMayhem Thanks! I had the obvious tnq:" first, but tn:" is a bit of a code smell (see this Matlab golfing tip) so I figured that tnq: could be more compact, too.

– Sanchises – 2016-09-18T08:24:49.883

4

Scala, 73 72 71 bytes

def f(s:String)=for(i<-1 to s.length){print(if(i%2>0)s else s.reverse)}

This is my first attempt at code golfing, so I'm sure there are countless improvements.

Update:

Golfed away 1 byte by removing brackets.

Thanks to Destructible Watermelon for suggestion, shaved off a byte.

Himself12794

Posted 2016-09-15T03:00:42.067

Reputation: 61

I don't know scala, but can you change i%2==1 to i%2>0? – Destructible Lemon – 2016-09-18T00:59:37.937

@DestructibleWatermelon Hadn't thought of that, yes I can – Himself12794 – 2016-09-18T01:40:06.400

3

Cubix, 52 bytes

Ap\:\;.#u/\:qqsoq(?;u.q..$u<../pB@u:\.....\(?q..s..p

On a cube:

      A p \
      : \ ;
      . # u
/ \ : q q s o q ( ? ; u
. q . . $ u < . . / p B
@ u : \ . . . . . \ ( ?
      q . .
      s . .
      p . .

This one was fun; there are bytes still to be golfed out of this but this will definitely work.

Try it online!

explanation:

Input of ABC

  • /A : go north and read in all inputs as characters; -1 will be at the bottom
  • p\;. : remove the -1 from the stack
  • u# : push the string length (number of items on the stack)
  • \:\:qq : dup the string length twice, push two copies to bottom of stack
  • loop:

    • soq(?/<u : swap top of stack, ouptut top of stack as ASCII, push top (letter) to bottom, decrement top of stack, turn right if not done, then move IP to the right place.
    • at end of loop, the stack will look like C B A 3 3 0
  • ;u : pop top of stack C B A 3 3

  • B : reverse stack 3 3 A B C
  • p( : move bottom to top and decrement 3 A B C 2
  • ? if top is zero, go straight to @ and terminate
  • else
    • psq:uq : move bottom to top, swap top and move top to bottom dup, and move top to bottom 3 2 A B C 3
    • $u : skip u
    • < puts us back into the loop.

Interpreter

Giuseppe

Posted 2016-09-15T03:00:42.067

Reputation: 21 077

Here's a 24 bytes one. Same general logic just compressed a little.

– MickyT – 2019-03-21T21:42:17.183

@MickyT I'd feel bad about taking credit for 28 bytes of golfing. Post it yourself! – Giuseppe – 2019-03-22T13:37:07.690

3

C (gcc), 88 87 85 83 68 66 83 82 78 bytes

-1 thanks to ceilingcat

Old version

p,q;f(char*s){p=q=1;for(char*m=s--;*m;s[p+=q]*p?:(m++,p+=q=-q))putchar(s[p]);}

Try it online!

Shorter version (slightly broken)

Riffing on the 76 byte approach by ASCII-only in the comments, and -1 byte from his tweak of my tweak.

Edit: This version is slightly broken in that it assumes that every string is preceded by a NULL byte, which is not always true. (See last test case in link). Reverting to the 83 byte version for now.

f(char*s){for(char*n=s-1,k=1;*s++;k=-k)for(;*(n+=k);)putchar(*n);}

Try it online!

gastropner

Posted 2016-09-15T03:00:42.067

Reputation: 3 264

67 – ASCII-only – 2019-03-23T02:29:07.030

@ASCII-only 68 is possible with some tweaking. – gastropner – 2019-03-23T02:31:59.117

:P it's 67 now lol @gastropner – ASCII-only – 2019-03-23T02:32:14.857

@ASCII-only 66 :-P – gastropner – 2019-03-23T02:36:31.353

@ASCII-only Sadly, the short version turns out to not work in certain cases. – gastropner – 2019-03-23T02:49:39.963

aw :( forgot that it isn't always preceded by a null byte. rip – ASCII-only – 2019-03-23T02:50:35.120

3

Dyalog APL, 8 bytes

∊≢⍴⊂,⊂∘⌽

flatten

the tally

cyclically reshaping

the enclosed argument

, followed by

⊂∘⌽ the enclosed reversed argument

TryAPL online!

-1 byte thanks to jimmy23013.

Adám

Posted 2016-09-15T03:00:42.067

Reputation: 37 779

∊≢⍴⊂,⊂∘⌽. And you counted 1 byte less. – jimmy23013 – 2016-09-15T13:33:04.850

@jimmy23013 I wrote the final score. ;-) – Adám – 2016-09-15T15:23:48.227

3

PowerShell v2+, 57 bytes

param($a)-join(1..($x=$a.length)|%{($a[$x..0],$a)[$_%2]})

No real clean way to get string lengths or reverse 'em, so this is pretty lengthy.

Takes input $a, loops from 1 to $a.length (stored in $x for use later). Each iteration we use a pseudo-ternary to index into an array of either $a or $a[$x..0] (i.e., reversed), based on whether our input number is odd/even [$_%2]. These are all encapsulated in parens and -joined together to form a single string. That's left on the pipeline, and output is implicit.

PS C:\Tools\Scripts\golfing> .\stringgnirts.ps1 'TimmyD'
TimmyDDymmiTTimmyDDymmiTTimmyDDymmiT

AdmBorkBork

Posted 2016-09-15T03:00:42.067

Reputation: 41 581

2

Japt, 11 bytes

ê1 pUÊ ¯Uʲ
ê1          // Append the reverse of the input to the input,
   pUÊ      // then repeat it input length times
       ¯Uʲ // and finally trim to length input length squared.

Try it online!

Nit

Posted 2016-09-15T03:00:42.067

Reputation: 2 667

1You're forgetting about î again, aren't you?! – Shaggy – 2018-04-13T16:15:00.043

@Shaggy I tried using it, but for the life of me, I can't get the hang of it. :P Thanks a lot for the example, though! – Nit – 2018-04-13T16:16:11.803

Sorry, posted the wrong link, it's actually 6 bytes.

– Shaggy – 2018-04-13T16:17:38.537

Here's a 6 byte solution – Oliver – 2018-04-13T23:25:55.130

@Oliver, the same alternative I came up with. Been debating whether I should post it. – Shaggy – 2018-04-14T00:32:32.653

1@Shaggy I wouldn't mind, and it's different enough than Nit's answer. Go for it man. – Oliver – 2018-04-14T00:34:44.247

2

05AB1E, 7 bytes

vDR}v}J

Try it online!

Will continue to work on it. I don't really like the "v}" part of it, can probably save a byte there.

Explanation

vDR}v}J

v         ; Iterates through each character
 D        ; Duplicate top of stack
  R       ; Push top of stack reversed
   }      ; end for loop
   v}     ; same as other v, effectively pops top of stack off
     J    ; Join everything together

Multi

Posted 2016-09-15T03:00:42.067

Reputation: 425

2vÂ}\J 5 bytes is the same as your code, but with the builtins you were looking for. :) Â is Bifurcate (short for Duplicate & Reverse, which is exactly what you're doing). \ deletes the top item on the stack. – Kevin Cruijssen – 2018-10-24T14:01:03.780

Also 5 bytes: R‚I∍J.

– Grimmy – 2020-01-22T16:56:31.550

2

brainfuck, 71 49 43 bytes

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

Try it online!

Thanks to Jo King for saving 6 bytes.

[Tape: [Letters], 0, counter]
,[          while input
  >+        increment old counter
  [>+<-]    move counter to next position
  ,         input next
]
>[          while counter
  <<[<]>    go to first letter
  [.>]      print word forwards
  >-        decrement counter
  [         if counter
    <<      go to last letter
    [.<]    print word backwards
    >[>]>-  decrement counter
    <       exit if
  ]
  >         go to counter
]

Dorian

Posted 2016-09-15T03:00:42.067

Reputation: 1 521

Thank you, Jo King. I didn't think it would be shorter that way. – Dorian – 2019-08-01T07:53:51.290

2

Keg, 6 bytes

(^(:,"

How it works

    Implicit Reversed Input
(   Runs X times, where X is the length of the stack
^   Reverse the stack
(   Runs X times, where X is the length of the stack
:,  Prints the top item of the stack as a character
"   Rolls the stack to the right (puts the top of the stack to the bottom)
    Ending brackets get auto-completed

Try it Online!

EdgyNerd

Posted 2016-09-15T03:00:42.067

Reputation: 1 106

The TIO does not work anymore... – None – 2019-08-12T02:48:07.567

Oh, did the latest pull request change anything I used here, because it was working before that? – EdgyNerd – 2019-08-12T06:46:32.577

Use the -lp and -ir flags instead – Lyxal – 2020-02-04T07:34:54.640

2

Java, 151 bytes

public static void r(String s){String t = new StringBuffer(s).reverse().toString();for(int i=0;i<s.length();i++){System.out.print(((i%2==1)?t:s));}}

}

Ungolfed:

public static void r(String s) {
    String t = new StringBuffer(s).reverse().toString();
    for(int i = 0; i < s.length();i++) {
        System.out.print(((i % 2 == 1) ? t : s));
    }
}

Herb Wolfe

Posted 2016-09-15T03:00:42.067

Reputation: 141

1

Hi, welcome to PPCG! First of all I'd like to recommend to read through Tips for golfing in Java. As for your code, there are a few things that can still be golfed: You can remove the public static before your method. You can remove the spaces between t=new StringBuffer. You can remove the unnecessary parenthesis and brackets. And you can swap the module check from ==1 to <1 (which is equivalent to ==0 for non-negative numbers). Also, you can move the i++ to the last usage inside the for-loop.

– Kevin Cruijssen – 2016-09-15T06:59:24.647

6So in total it becomes: void r(String s){for(int i=0;i<s.length();)System.out.print(i++%2<1?s:new StringBuffer(s).reverse()+"");} (105 bytes) – Kevin Cruijssen – 2016-09-15T07:01:34.010

2

Java, 127 111 88 bytes

(s,r)->{for(int i=0;i++<s.length();)r+=i%2<1?new StringBuffer(s).reverse():s;return r;};

Ungolfed test program

    public static void main(String[] args) {
    BiFunction<String, String, String> func = (s, r) -> {
        for (int i = 0; i++ < s.length();) {
            r += i % 2 < 1 ? new StringBuffer(s).reverse() : s;
        }
        return r;
    };
    System.out.println(func.apply("Hello!", ""));
}

Shaun Wild

Posted 2016-09-15T03:00:42.067

Reputation: 2 329

This can be golfed some more: (s,r)->{for(int i=0;i++<s.length();)r+=i%2<1?s:new StringBuffer(s).reverse();return r;}; (88 bytes). Also, I would specify that this is Java 8. – Kevin Cruijssen – 2016-09-15T08:26:25.057

Na, it's fine to assume that his is using the latest version of Java. – Shaun Wild – 2016-09-15T09:46:38.257

@KevinCruijssen Java 7 is not supported anymore (except with big $$$). We shouldn't have to specify the version of Java. Also, if you write as Java 7, most of the answers can be written in Java 1.1 or 1.2. So shouldn't you write the lowest version with which it works? If the code in this answer was Java 7 compliant, it'd be Java 1.2 compliant, and... would still work in Java 8.

– Olivier Grégoire – 2016-09-15T12:18:57.473

2

CJam, 10 bytes

l_,({_W%}*

Try it online!

Explanation

l            e# Read line
 _           e# Duplicate
  ,(         e# Length minus 1
    {   }*   e# Run code block that many times
     _       e# Duplicate
      W%     e# Reverse
             e# Implicitly display

Luis Mendo

Posted 2016-09-15T03:00:42.067

Reputation: 87 464

2

R, 53 bytes

Assumes that the input is space- or newline-separated for each character.

cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")

Some test cases:

> cat(rep(c(i<-scan(,""),rev(i)),len=length(i)^2),sep="")
1: h e l l o !
7: 
Read 6 items
hello!!ollehhello!!ollehhello!!olleh

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: a
2: 
Read 1 item
a

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: a b c d
5: 
Read 4 items
abcddcbaabcddcba

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: O K !
4: 
Read 3 items
OK!!KOOK!

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: 4 8 1 5 1 6 2 3 4 2
11: 
Read 10 items
4815162342243261518448151623422432615184481516234224326151844815162342243261518448151623422432615184

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: P P C G
5:    
Read 4 items
PPCGGCPPPPCGGCPP

> cat(rep(c(i<-scan(,""),rev(i)),l=length(i)^2),sep="")
1: 4 2
3: 
Read 2 items
4224

rturnbull

Posted 2016-09-15T03:00:42.067

Reputation: 3 689

2

Octave, 39 35 bytes

@(x)[x'+~x;flip(x'+~x),''](1:end/2)

f('Hello!')
ans = Hello!!olleHHello!!olleHHello!!olleH

Explanation:

@(x)            % Take x as input, inside apostrophes 'Hello!'
x'+~x           % Create a mesh of the ASCII-code of the input letters
                % For input `bcd` this will be:
                %    98    98    98
                %    99    99    99
                %   100   100   100
;flip(x'+~x)   % Concatenate vertically to create:
                %    98    98    98
                %    99    99    99
                %   100   100   100
                %   100   100   100
                %    99    99    99
                %    98    98    98
___,'']         % Short cut to convert ASCII-code to characters
(1:end/2)       % Display the first half of this array of letters, as a
                % horizontal string

Saved 4 bytes thanks to Luis. ~x instead of 0*x saved one byte (works because all elements of x are non-zero. flip instead of flipud saved another two bytes (I didn't know flip existed).

Stewie Griffin

Posted 2016-09-15T03:00:42.067

Reputation: 43 471

2

C#, 94 bytes

using System.Linq;string R(string n)=>string.Concat(n.SelectMany((c,i)=>1>i%2?n:n.Reverse()));

76 bytes for the method + 18 bytes for LINQ import.

How it works:

using System.Linq; // Required for LINQ extension methods.

string R(string n) => 
    string.Concat( // Concatenate the following chars into a single string
        n.SelectMany( // Enumerate each char in n, flattening the returned IEnumerable<char>'s into a single IEnumerable<char>
            /*IEnumerable<char> Lambda*/(/*char*/ c, /*int*/ i) => // i = index in n
                1 > i % 2 // Check if i is even or odd
                    ? n // if i is even, add n to the concat
                    : n.Reverse() // else reverse n and concat that
        )
    )
;

milk

Posted 2016-09-15T03:00:42.067

Reputation: 3 043

2

bash + util-linux, 68 58 53 bytes

y=$1;for((i;i<${#1};i++)){ echo -n $y;y=`rev<<<$y`;}

Explanation

Two things with the for loop:

  • There is an apparently undocumented way of writing for loops where one replaces the do and done keywords with curly braces { and }. The space after the first bracket is necessary, and the semicolon at the end is also necessary.
  • It turns out that in the "C-style" for loops, you can just initialize with i; instead of using i=0;.
  • The ${#1} part of the condition i < ${#1} refers to the length of our input (the first parameter $1). In general, you can use ${#foo} to retrieve the size of the string $foo.

Additionally:

  • rev is the tool in util-linux that reverses a string.
  • We need to pass the -n flag to echo to get rid of newlines.
  • The expression rev<<<$y is called a here-string (see this relevant tldp.org page), which passes the variable $y to the standard input of rev.

frames

Posted 2016-09-15T03:00:42.067

Reputation: 41

Please explain some of your knowledge. Also perhaps the space before the echo may be removable, I am not knowledgable on bash though – Rohan Jhunjhunwala – 2016-09-18T01:47:49.123

@RohanJhunjhunwala Added a little explanation to the answer to maybe help clarify some things. Also: when omitting the do and done keywords in a for loop, you actually do need that space! – frames – 2016-09-19T23:37:34.427

+1 looks good now. I onlly commented because your code drew an automatic low quality flag. Code-only answers get auto flagged – Rohan Jhunjhunwala – 2016-09-20T00:39:30.440

y=$1;for((;i<${#1};i++)){ printf $y;y=\rev<<<$y`;}` ... saved a couple of bytes – roblogic – 2019-03-23T20:03:15.870

1

Excel VBA, 59 Bytes

Anonymous VBE immediate window function that takes input from range [A1] and outputs to the VBE immediate window

a=[A1]:For i=1To Len(a):?IIf(i mod 2,a,StrReverse(a));:Next

Taylor Scott

Posted 2016-09-15T03:00:42.067

Reputation: 6 709

1

Pushy, 5 bytes

NL:"@

Try it online!

Explanation

N          \ Suppress newlines in printing
 L:        \ Len(String) times do:
   "       \    Print
    @      \    Reverse

FlipTack

Posted 2016-09-15T03:00:42.067

Reputation: 13 242

1

CJam, 15 10 bytes

q_,{_W%}*;

Explanation:

e.g input: "hello"
q //reads input, pushes to the stack. Stack: hello
  _ //duplicates it. Stack: hello, hello
   , //finds the length.  Stack: hello, 5
    { //starts a block.
     _ //duplicates the input. WouldBeStack: hello hello
      W // -1. WouldBeStack: hello -1
       % // Reverse (-1 = reverse, % = select every nth item). WouldBeStack: hello olleh
         } //end the block. Stack: hello, 5, {_W%}
           * //repeat the block for length times. Stack: hello, olleh, hello, olleh, hello, olleh
              ; //discard the last element

Try it online!

lolad

Posted 2016-09-15T03:00:42.067

Reputation: 754

1

Add++, 23 bytes

L,dbRB]AbLdVß*GB VcGbUJ

Try it online!

caird coinheringaahing

Posted 2016-09-15T03:00:42.067

Reputation: 13 702

1

Perl 6, 25 bytes

{S:g{.}=$++%2??.flip!!$_}

Try it online!

-4 bytes thanks to Jo (the) King!


Perl 6, 29 bytes

{S:g/./{$/.to%2??$_!!.flip}/}

Wanted to avoid a concatenation, so this just substitutes every character S:g/./ ... / with either the input $_ or its reverse .flip depending on whether the match position $/.to is odd or even %2.

Try it online!

Phil H

Posted 2016-09-15T03:00:42.067

Reputation: 1 376

can't use $++ here? – Ven – 2019-03-21T21:18:39.530

@Ven I think because its state gets reset every time the {} interpolation happens. However, if the code isn't being interpolated, this can be 25 bytes

– Jo King – 2019-03-22T02:26:37.530

1

Gol><>, 16 bytes

iEv
|;>lFrllKRo~

Try it online!

How it works

iEv

i    Take input as a char
 E   If the last input was EOF, pop; otherwise skip once
iEv  Take all input until EOF, then move to the next line

|;>lFrllKRo~

  >           Move right
   l          Push stack length (== string length)
    F         Pop x and repeat up to matching `|` x times

              [...string]
     r        Reverse stack
              [...rstring]
      ll      Push n, n+1
              [...rstring n n+1]
        K     Pop x and push copy of top x elements
              [...rstring n ...rstring n]
         R    Pop x and repeat the next instruction x times
          o   Pop and print as char
         Ro   Pop n and print n chars in reverse order
              [...rstring n]
           ~  Pop and discard
              [...rstring]

|             End `F` loop
 ;            Halt

Alternative solution, 16 bytes

iEv
|;>lFrlFLko|

Try it online!

How it works

iEv           Same as above

|;>lFrlFLko|

   l          Push n
    F         Pop n, repeat outer loop n times
     r        Reverse stack
      l       Push n
       F      Pop n, repeat inner loop n times
        L     Push loop counter (refers to the inner loop)
         k    Pop x and copy the x-th element to the top
          o   Pop and print as char
           |  Close inner loop
|             Close outer loop
 ;            Halt

Bubbler

Posted 2016-09-15T03:00:42.067

Reputation: 16 616

1

SNOBOL4 (CSNOBOL4), 107 91 bytes

	O =N =INPUT
I	X =LT(X,SIZE(N) - 1) X + 1	:F(O)
	N =REVERSE(N)
	O =O N	:(I)
O	OUTPUT =O
END

Try it online!

This should now be fairly close to Suever's MATL solution.

Giuseppe

Posted 2016-09-15T03:00:42.067

Reputation: 21 077

1

Tcl, 77 bytes

proc S {s i\ 0} {if $i<[string le $s] {set s $s[S [string rev $s] [incr i]]}}

Try it online!


Tcl, 88 bytes

proc S s {time {append r [expr [incr i]%2?"$s":"[string rev $s]"]} [string le $s]
set r}

Try it online!


Tcl, 91 bytes

proc S s {append r $s
time {set r $r[set s [string rev $s]]} [expr [string le $s]-1]
set r}

Try it online!

sergiol

Posted 2016-09-15T03:00:42.067

Reputation: 3 055

1

Cubix, 24 bytes

..@wA#s?sBp\).W\oq>(?v()

Try it online!

Unwraps onto the following cube

    . .
    @ w
A # s ? s B p \
) . W \ o q > (
    ? v
    ( )

Watch it run

  • A# Take all from input and push the number of items on the stack. This includes the -1 for the end of input.
  • s? Swap the TOS and test value
    • wsBp\((? If negative (end of word), change lane to the right, swap TOS, reverse stack, bring botton of stack to the top, decrement twice and test
      • W#@ If 0 (repetitions finished) change lane to the left, redundant count of stack and halt
      • v)>()W If still positive, redirect down, increment, redirect right, decrement, increment and shift lane right back into the print loop
    • \oq>()W If positive, reflect left, output character, push TOS to bottom, redirect right, increment, decrement and shift lane left into the print loop

MickyT

Posted 2016-09-15T03:00:42.067

Reputation: 11 735

1

Pip, 20 17 bytes

Fi,#a{i%2?ORVaOa}

Try it online!

(RV reverses iterable). The program outputs the string on even steps and the reverse on odd steps

Kenneth Taylor

Posted 2016-09-15T03:00:42.067

Reputation: 183

1

C# (Visual C# Interactive Compiler), 43 bytes

s=>s.SelectMany((_,i)=>i%2<1?s:s.Reverse())

Try it online!

dana

Posted 2016-09-15T03:00:42.067

Reputation: 2 541

1

K (oK), 18 bytes

Solution:

,//(#x)#(,;|)@\:x:

Try it online!

Explanation:

Apply enlist , and reverse | to the input and take length-of-input from this

,//(#x)#(,;|)@\:x: / the solution
                x: / store input as x
             @\:   / apply (@) each-left (\:)
        ( ; )      / two-item list
           |       / reverse
         ,         / enlist
       #           / take
   (  )            / do this together
    #x             / count x
,//                / flatten (,/) until converges

streetster

Posted 2016-09-15T03:00:42.067

Reputation: 3 635

1

Zsh, 46 41 bytes

repeat $#1 s+=$1${(j::)${(Oas::)1}}
<<<$s

Try it online! Try it online!

       ${(Oas::)1}
       ${       1}    # take first parameter
         (  s::)      # split into characters
         (Oa   )      # reverse order
${(j::)           }   # join

GammaFunction

Posted 2016-09-15T03:00:42.067

Reputation: 2 838

1

Python2, 109 99 89 bytes

def f(s,o=''):
 r=s[::-1]
 for i in range(len(s)):
  if i%2==0:o+=s
  else:o+=r
 return o

Try it online!

or

Python2, 53 bytes

Saved 36 bytes, thanks to Jonathan French's solution:

lambda s:''.join(s[::~i%2*2-1]for i in range(len(s)))

Try it online!

Pandazoic

Posted 2016-09-15T03:00:42.067

Reputation: 121

53 bytes. – Jonathan Frech – 2019-08-12T03:30:24.007

As general golfing tips: You can negate i%2==0 to i%2!=0 and swap your two branches. Then the condition reduces to i%2. Furthermore, r is only referenced once and thus can be substituted with its value. You can shrink the iterative for loop into a generator and concatenate the result, yielding a one-line lambda expression. I also recommend reading the Python tips page.

– Jonathan Frech – 2019-08-12T03:33:51.213

Thanks, these are all terrific tips and great link! If a comment presents an improvement that follows the basic idea of the original, should I either replace the original or add an update section to it? – Pandazoic – 2019-08-12T03:37:52.450

It is up to you. Most of the time, a golfing suggestion is incorporated into the answer, improving its byte count and crediting the source. Sometimes the changes are too drastic and one wants to retain multiple solutions, albeit of differing byte count. – Jonathan Frech – 2019-08-12T03:43:40.453

1

PowerShell, 44 bytes

-join(($a=$args)|%{$a;$a=$a[-1..-$a.Count]})

Try it online!

Takes input via splatting, essentially making it an array of chars.

mazzy

Posted 2016-09-15T03:00:42.067

Reputation: 4 832

1

Wren, 39 bytes

Beats Python by 1 byte.

Fn.new{|n|(n=n[-1..0]).map{n=n[-1..0]}}

Try it online!

Explanation

Fn.new{|n|                            } // Anonymous function with n
          (n=n[-1..0])                  // Step 1. Set n as the reverse of n
                                        // Before the mapping of every item
                                        // in this list. Why? Because the
                                        // initialization in the map function
                                        // is done *before* the value is returned.

                      .map{          }  // Step 2. Map every item in this list
                           n=n[-1..0]   // to the current state of this string
                                        // reversed.
```

user85052

Posted 2016-09-15T03:00:42.067

Reputation:

1

Ruby, 34 bytes

->s{s.each_char{$><<s;s.reverse!}}

Try it online!

This goes through each character of the string (a loop that runs as many times as the length of the string) and prints the string, and then reverses it.

$><<s is a golfed version of print s. It appends (<<) the value (s) to stdout ($>).

IMP1

Posted 2016-09-15T03:00:42.067

Reputation: 510

1

Java 8 bytecode, 412 bytes (403 bytes + -noverify)

Hexdump because it's unprintables all the way down:

00000000: cafe babe 0003 002d 0020 0a00 0c00 040c  .......-. ......
00000010: 0017 001f 0100 1628 5b4c 6a61 7661 2f6c  .......([Ljava/l
00000020: 616e 672f 5374 7269 6e67 3b29 560c 000e  ang/String;)V...
00000030: 0010 0100 063c 696e 6974 3e07 0011 0100  .....<init>.....
00000040: 0570 7269 6e74 0100 066c 656e 6774 6807  .print...length.
00000050: 0015 0100 0443 6f64 6501 0004 6d61 696e  .....Code...main
00000060: 0700 1609 0009 0002 0100 0772 6576 6572  ...........rever
00000070: 7365 0100 0a53 6f75 7263 6546 696c 6501  se...SourceFile.
00000080: 001a 2829 4c6a 6176 612f 6c61 6e67 2f53  ..()Ljava/lang/S
00000090: 7472 696e 6742 7566 6665 723b 0100 136a  tringBuffer;...j
000000a0: 6176 612f 696f 2f50 7269 6e74 5374 7265  ava/io/PrintStre
000000b0: 616d 0100 0328 2949 0a00 0600 140c 0007  am...()I........
000000c0: 001c 0100 106a 6176 612f 6c61 6e67 2f53  .....java/lang/S
000000d0: 7973 7465 6d01 0016 6a61 7661 2f6c 616e  ystem...java/lan
000000e0: 672f 5374 7269 6e67 4275 6666 6572 0100  g/StringBuffer..
000000f0: 036f 7574 0a00 0c00 1d07 000a 0c00 0500  .out............
00000100: 1c0a 000c 001a 0100 1528 4c6a 6176 612f  .........(Ljava/
00000110: 6c61 6e67 2f53 7472 696e 673b 2956 0c00  lang/String;)V..
00000120: 0800 1201 0000 0100 154c 6a61 7661 2f69  .........Ljava/i
00000130: 6f2f 5072 696e 7453 7472 6561 6d3b 0020  o/PrintStream;.
00000140: 0019 0006 0000 0000 0001 0009 000b 0003  ................
00000150: 0001 000a 0000 0031 0004 0001 0000 0025  .......1.......%
00000160: bb00 0c59 2a03 32b7 001b 59b6 0018 3b59  ...Y*.2...Y...;Y
00000170: b200 0d5f b600 13b6 0001 c484 0000 ffff  ..._............
00000180: 1a9a ffee b100 0000 0000 0100 0f00 0000  ................
00000190: 0200 1e 

Jasmin assembly code:

.source ""
.class Code
.super java/io/PrintStream
.method public static main([Ljava/lang/String;)V
    .limit stack 4
    .limit locals 1
    new java/lang/StringBuffer
    dup
    aload_0
    iconst_0
    aaload
    invokenonvirtual java/lang/StringBuffer/<init>(Ljava/lang/String;)V
    dup
    invokevirtual java/lang/StringBuffer/length()I
    istore_0
    Loop:
        dup
        getstatic java/lang/System/out Ljava/io/PrintStream;
        swap
        invokevirtual java/io/PrintStream/print(Ljava/lang/String;)V
        invokevirtual java/lang/StringBuffer/reverse()Ljava/lang/StringBuffer;
        iinc 0 -1
        iload_0
        ifne Loop
        return
.end method

What CFR thinks this decompiles to (it's actually mostly correct this time):

/*
 * Decompiled with CFR 0.148.
 */

import java.io.PrintStream;

class Code
extends PrintStream {
    public static void main(String[] arrstring) {
        StringBuffer stringBuffer = new StringBuffer(arrstring[0]);
        StringBuffer stringBuffer2 = stringBuffer;
        int n = stringBuffer.length();
        do {
            System.out.print((String)((Object)stringBuffer2));
            stringBuffer2 = stringBuffer2.reverse();
        } while (--n != 0);
    }
}

Needs -noverify because the JVM will just kinda cast it anyways, allowing me to save on needing the (Ljava/lang/Object;)V descriptor

famous1622

Posted 2016-09-15T03:00:42.067

Reputation: 451

1

PHP, 54 bytes

while($i++<strlen($s=$argv[1])){echo$s;$s=strrev($s);}

There are a lot of ways to do that, in almost every language I guess.


These two are my favourites:

an evil eval (62 bytes)

eval(str_repeat('echo$s;$s=strrev($s);',strlen($s=$argv[1])));

and a substr solution (69 bytes)

<?=substr(str_repeat(($s=$argv[1]).strrev($s),$n=strlen($s)),-$n*$n);

and while we´re at unsensible coding, take these 61:

$s=$argv[1];L:echo$s;$s=strrev($s);if(++$i<strlen($s))goto L;

Titus

Posted 2016-09-15T03:00:42.067

Reputation: 13 814

1

Brachylog, 16 bytes

l-I,?r:?r:Ij@2hc

Try it online!

Explanation

l-I,                I = length(Input) - 1
    ?r              Reverse the Input
      :?r           The list [Input, Reverse of the Input]
         :Ij        Append I times that list to itself
            @2h     Split in half and take the first part
               c    Concatenate into a string

Fatalize

Posted 2016-09-15T03:00:42.067

Reputation: 32 976

1

Retina, 27 bytes

Byte count assumes ISO 8859-1 encoding.

.
±$_
O$^`(?(\G)[^±]|±)

±

Try it online!

Explanation

.
±$_

Replace each character with the entire input, preceded by ± to separate copies.

O$^`(?(\G)[^±]|±)

The regex matches the characters in every other copy, by either matching a ± that is not adjacent to the previous match, or a non-± that is. These characters are reversed. Since each copy is the same width that is identical to reversing each copy individually.

±

Remove the separators.

Martin Ender

Posted 2016-09-15T03:00:42.067

Reputation: 184 808

1

Straw, 10 bytes

<:(:>"),*&

Try it online!

<:(:>"),*&
<          Take the input       (Stack: ["", input])
 :         Duplicate            (Stack: ["", input, input])
  (        Start a string
   :       Duplicate
    >      Output
     "     Reverse
      )    End the string       (Stack: ["", input, input, ':>"'])
       ,   Swap                 (Stack: ["", input, ':>"', input])
        *  Unary multiplication (Stack: ["", input, ':>"'*length of input])
         & Evaluate             (Stack: ["", input])

TuxCrafting

Posted 2016-09-15T03:00:42.067

Reputation: 4 547

1

Pyth, 6 bytes

Vzp~_z

Try it online!

Explanation

Vzp~_z
Vz      For every character in z (the input)
  p  z  Print z
   ~_z  Reverse z

insert_name_here

Posted 2016-09-15T03:00:42.067

Reputation: 816

1

Pyke, 8 7 bytes

VoI_Q(s

Try it here!

Blue

Posted 2016-09-15T03:00:42.067

Reputation: 26 661

Works, but also gives an error "RUNNING: 'VoI_Q(s' Missing arg to Repeat, evaling input.BAD EVAL STACK" – GolezTrol – 2016-09-16T21:32:31.217

@GolezTrol If you run it without warnings it doesn't do that. Also by default stderr can be ignored – Blue – 2016-09-16T21:35:50.037

1

Lua, 66 bytes

function f(s,i)j=i or 0return#s>j and s..f(s:reverse(),j+1)or''end

Try it on ideone!

Scepheo

Posted 2016-09-15T03:00:42.067

Reputation: 466

While my Lua solution is shorter (62 bytes) and is full program, your is far more creative. Good job! – val says Reinstate Monica – 2019-08-01T11:54:15.013

1

Julia, 42 bytes

h(s,l=1)=l==endof(s)?s:s*h(reverse(s),l+1)

Recursive function with counter variable l. If it is equal to the length of the string s, simply return it, otherwise concatenate (s*...) it with h(reverse(s),...) while incrementing the counter l+1.

ojdo

Posted 2016-09-15T03:00:42.067

Reputation: 410

1

><>, 34 bytes

l::f1.>1!<-{:o$61.
:?!;1-$:?^~r:@@

Input for using the -v flag.

Explanation

l::f1.Captures the length of the input, and creates two copies of it. One of the copies is used to keep track of the number of loops, the other one is used in the loop that prints the string. After that, the program teleports to the end of the second line, wraps around, and enters the main loop.

:?!;1-$ Checks if the program has printed the string n times, and if so, it terminates. Otherwise, it decrements the number of strings remaining.

:?^~r:@@ Checks if the program is done printing one iteration of the loop. If so, it reverses the string.

>1!<-{:o$61. Prints the next character in the string, and decrements the index. Teleports back to previous conditional.

Try it online!

SE - stop firing the good guys

Posted 2016-09-15T03:00:42.067

Reputation: 529

The flag for strings is the -s flag, whereas -v is used for numbers. The other flags (-t and -a) are rarely used. 23 bytes.

– Jo King – 2018-04-13T11:00:06.610

1

Vitsy, 10 bytes

Wl\[::ZYr]

W          Grab a line from STDIN.
 l\[     ] Store the length of the stack as x, do the stuff in brackets x times.
    ::     Clone the current stack twice.
      Z    Output the current stack.
       Y   Pop and dump this stack, returning back to previous.
        r  Reverse the current stack.

Try it online!

Addison Crump

Posted 2016-09-15T03:00:42.067

Reputation: 10 763

1

Haxe, 121 118 117 bytes

function R(s:String){var r="",o="",l=s.length;for(i in-l+1...1)r+=s.charAt(-i);for(i in 0...l)o+=i%2<1?s:r;trace(o);}

Reverting the string took a lot of bytes :(

Testcases

R("a")
a

R("Hello!")
Hello!!olleHHello!!olleHHello!!olleH

R("4815162342")
4815162342243261518448151623422432615184481516234224326151844815162342243261518448151623422432615184

Yytsi

Posted 2016-09-15T03:00:42.067

Reputation: 3 582

Could you link to a online test suite or some other resource to test this code? I am having a spot of trouble compiling your code on my machine. – Post Rock Garf Hunter – 2016-09-18T15:39:28.237

@WheatWizard Try this: http://try.haxe.org/#eE97b

– Yytsi – 2016-09-18T15:44:39.800

Couldn't you split the string to an array of char and reverse that array? (if it's shorter...) – Paul Picard – 2016-09-18T16:53:36.440

@PaulPicard Tried that already, but it was longer :( – Yytsi – 2016-09-18T16:58:03.167

@PaulPicard FWIW: it's actually longer to reverse the string inside an array comprehension, and join back together, than the method I use here :D – Yytsi – 2016-09-19T03:52:49.067

1

><>, 40 bytes

<v?(0:i
l\~l&r
$<v!?:-1}o:
;^>~rl&1-:&?!

Try it online!

Sok

Posted 2016-09-15T03:00:42.067

Reputation: 5 592

1

Vimscript - 109 bytes

@DJMcMayhem already beat me to it, but because I did it anyway, here's my losing answer. I thought reversing a string would be easier though!

fu A(s)
let i=0
wh(i<len(a:s))
exe "norm A". [a:s,join(reverse(split(a:s,'\zs')),'')][i%2]
let i+=1
endw
endf

Ungolfed

function! A(s)
  let reversed=join(reverse(split(a:s,'\zs    ')),'')
  let both=[a:s,reversed]
  let i=0
  while(i<len(a:s))
    exe "norm a".both[i%2]
    let i+=1
  endwhile
endfunction

Christian Rondeau

Posted 2016-09-15T03:00:42.067

Reputation: 301

0

Implicit, 10 bytes

'¯^(]%\[´ö

Try it online!

Explanation:

'¯^(]%\[´ö
'           « read string               »;
 ¯          « copy to memory            »;
  ^         « push string length        »;
   (......  « infinite loop             »;
    ]       «  pull string to stack     »;
     %      «  print string             »;
      \     «  reverse it               »;
       [    «  put it back in memory    »;
        ´   «  decrement string length  »;
         ö  «  exit w/o implicit output if top of stack falsy, shortcut for )&  »;

MD XF

Posted 2016-09-15T03:00:42.067

Reputation: 11 605

0

Japt, 6 bytes

ʲîUpw

Try it

ʲîUpw     :Implicit input of string U
Ê          :Length
 ²         :Squared
  î        :Repeat to that length
   Up      :  Append to U
     w     :    Reverse U

Shaggy

Posted 2016-09-15T03:00:42.067

Reputation: 24 623

0

ES7, 60 bytes

b=>{for(c=b,d=0;d++<b.length;)c+=d%2?b:b.reverse();return c}

elipszilon

Posted 2016-09-15T03:00:42.067

Reputation: 61

0

APL(NARS), 23 chars, 46 bytes

{⍵{⍵≤1:⍺⋄⍺,(⌽⍺)∇⍵-1}≢⍵}

test:

  f←{⍵{⍵≤1:⍺⋄⍺,(⌽⍺)∇⍵-1}≢⍵}
  f ,'a'
a
  f 'Hello!'
Hello!!olleHHello!!olleHHello!!olleH
  f 'abcd'
abcddcbaabcddcba
  f 'OK!'
OK!!KOOK!

RosLuP

Posted 2016-09-15T03:00:42.067

Reputation: 3 036

0

PicoLisp, 70 bytes

(de f(s)(for n(size s)(prin(if(= 1(% n 2))s(pack(reverse(chop s)))))))

Try it online!

Galen Ivanov

Posted 2016-09-15T03:00:42.067

Reputation: 13 815

0

Red, 43 bytes

func[s][foreach c s[prin copy s reverse s]]

Try it online!

Galen Ivanov

Posted 2016-09-15T03:00:42.067

Reputation: 13 815

0

Factor, 62 bytes

: f ( x -- x ) [ length ] keep [ dup write reverse ] repeat ; 

Try it online!

Galen Ivanov

Posted 2016-09-15T03:00:42.067

Reputation: 13 815

0

Gaia, 10 bytes

:l┅r¦iv?¦$

Try it online!

:		| duplicate input
 l		| take length
  ┅		| push range 1,2,3,...l
    r¦		| modulo 2 1,0,1,...l%%2
      iv?¦	| if truthy, push same, else push reverse
          $	| join with no separator and display

Giuseppe

Posted 2016-09-15T03:00:42.067

Reputation: 21 077

0

Ohm v2, 5 bytes

lMDLR

Try it online!

Cinaski

Posted 2016-09-15T03:00:42.067

Reputation: 1 588

0

Swift 5, 70 bytes

{a in String(zip(0..., a).flatMap{$0.0%2==0 ?a:String(a.reversed())})}

Try it online!

Tiziano Coroneo

Posted 2016-09-15T03:00:42.067

Reputation: 141

0

Lua, 62 bytes

a=arg[1]for i=1,#a do io.write(i%2==1 and a or a:reverse())end

Try it online!

Full program, take input as argument.

val says Reinstate Monica

Posted 2016-09-15T03:00:42.067

Reputation: 409

0

Kotlin, 67 bytes

{s->Array(s.length){if(it%2>0)s.reversed()else s}.joinToString("")}
  • Initialize an array of s.length elements.
  • Choose direction based on index
  • Concat it all together

Try it online!

Brojowski

Posted 2016-09-15T03:00:42.067

Reputation: 141

0

Julia 1.0, 35 bytes

s->for _=s print(s);s=reverse(s)end

Try it online!

Loops over the input string characters and each iteration prints and reverses the string.

TimD

Posted 2016-09-15T03:00:42.067

Reputation: 71

0

Keg, 8 bytes

᠀:(⑴;|⑩⑶

Try it online!

I found this to be quite a fun little answer to write.

Explained

᠀:(⑴;|⑩⑶
᠀:          #Take input as a string (otherwise numbers won't work correctly) and duplicate it, because:
  (⑴        #We then push the length of that string onto the stack. The ⑴ op pops the top however, which is why duplication was needed. This will be the loop count of our for loop, started with "("
    ;       #Decrement that length to avoid off by one error
     |      #Branch to the body of the for loop
      ⑩⑶    #Print the item without popping and then reverse that item

Oh unicode... why'd y'all have to be so unevenly widthed for?

Lyxal

Posted 2016-09-15T03:00:42.067

Reputation: 5 253

0

Burlesque, 15 bytes

saS[jJ<-_+cyj.+

Try it online!

sa  # Length of input
S[  # Squared
jJ  # Duplicate the input
<-  # Reverse it
_+  # Join them
cy  # Repeat infinitely
j.+ # Take the first length-squared characters

DeathIncarnate

Posted 2016-09-15T03:00:42.067

Reputation: 916

0

C++ (gcc), 112 bytes

#import<bits/stdc++.h>
int f(std::string&s){for(int x=s.length();x--;std::reverse(&s[0],&*end(s)))std::cout<<s;}

Requires a non-const, mutable std::string. It reverses the string after every iteration and prints it.

-3 bytes thanks to ceilingcat!

Try it online!

S.S. Anne

Posted 2016-09-15T03:00:42.067

Reputation: 1 161

@ceilingcat Thank you! Incorporated. – S.S. Anne – 2020-02-04T23:55:48.270

0

Ruby, 43 bytes

f=->s,i=s.size{$><<s
i<2||f[s.reverse,i-1]}

See it on eval.in: https://eval.in/642616

Jordan

Posted 2016-09-15T03:00:42.067

Reputation: 5 001

0

Actually, 12 bytes

;;l)Rkp;)αHΣ

Try it online!

Explanation:

;;l)Rkp;)αHΣ
;;l           dupe string twice, use one copy to get length (call it L)
   )          move length to bottom of stack
    R         reverse one copy of string
     k        pop entire stack and push as list
      p       pop L from list
       ;)     dupe L, move one copy to bottom
         α    repeat each element (the forward and reversed string) of the list L times
          H   first L elements in list (trim off excess elements)
           Σ  concatenate

Mego

Posted 2016-09-15T03:00:42.067

Reputation: 32 998

0

Groovy, 51 bytes

def d(s){s.size().times{print(it%2?s.reverse():s)}}

norganos

Posted 2016-09-15T03:00:42.067

Reputation: 51

Anonymous function/proc/lambda/closure/whatever each language may call them, are also acceptable: {s->s.each{print(s);s=s.reverse()}}. – manatwork – 2016-09-15T08:19:24.943

you should post that as your own solution. this is much better than my version! you significantly improved it, so you should earn the groovy trophy for this! – norganos – 2016-09-15T08:36:18.510

0

Lua 5.1, 70 Bytes

function f(s)return(s..s:reverse()):rep(#s/2)..(#s%2==1 and s or"")end

Had odd numbers not been possible, I could have done it in 48 bytes by sheering off the ..(#s%2==1 and s or""), but the test cases prevented that.

This was the shortest of three methods I tried, the others being.

function f(s)local o return s:gsub(".",function()o=~o return o and s or s:reverse()end)end

and

function f(s)local o,t t=""for _ in s:gmatch(".")do o,t=~o,t..(o and s:reverse()or s)end return t end

the locals were added in those two examples, for confidence that this function would always work.

ATaco

Posted 2016-09-15T03:00:42.067

Reputation: 7 898

>

  • This doesn't work on odd numbers, because rep only takes integers (use // instead).
  • You can make up for the byte lost by that by switching the and..or around.
  • < – Scepheo – 2016-09-15T12:32:07.197

    Which version of Lua? Your gsub() solution not works with Lua 5.1.5 (“unexpected symbol near '~'”) and Lua 5.3.1 (“attempt to perform bitwise operation on a nil value (upvalue 'o')”). So no idea what you are doing in that callback function, but this way looks shorter: function(s)return s:gsub(".",function()o=s;s=s:reverse();return o end)end. – manatwork – 2016-09-15T12:35:40.007

    Only the top code is my submitted solution, function f(s)return(s..s:reverse()):rep(#s/2)..(#s%2==1 and s or"")end, secondly, :rep floors the value, and the ..(#%2==1 and s or"") accounts for odd numbers. – ATaco – 2016-09-16T00:55:04.270

    0

    C#, 137 bytes

    void S(string i){Console.WriteLine(string.Join("",i.Select((c,n)=>(n%2==0)?i:i.Reverse()).Select(x=>new string(x.ToArray())).ToList()));}
    

    Ungolfed:

    void S(string i)
    {
        Console.WriteLine(string.Join("",
        i.Select((c, n) => (n%2 == 0) ? i : i.Reverse()).Select(x => new 
        string(x.ToArray())).ToList()));
    }
    

    Jakub Jankowski

    Posted 2016-09-15T03:00:42.067

    Reputation: 101

    All the usings are missing in this answer: those would add another 31 bytes. – Scepheo – 2016-09-15T08:59:25.057

    Since no-one said it yet, welcome to PPCG! – Erik the Outgolfer – 2016-09-15T11:39:29.113

    0

    Java, 68 bytes

    b->s->{for(int i=b.reverse().length();i-->0;)s.append(b.reverse());}
    

    Or if the 2nd argument isn't allowed, 79 bytes:

    b->{String s="";for(int i=b.reverse().length();i-->0;)s+=b.reverse();return s;}
    

    Testing and ungolfed

    import java.util.function.BiConsumer;
    import java.util.function.Function;
    
    public class Main {
    
      public static void main(String[] args) {
    
        // Shortest version
        BiConsumer<StringBuilder, StringBuilder> f = (in, out) -> {
          in.reverse();
          for (int i = in.length(); i-- > 0;) {
            out.append(in.reverse());
          }
        };
        // Longer version
        Function<StringBuilder, String> g = in -> {
          String out = "";
          in.reverse();
          for(int i = in.length(); i-->0; ) {
            out+=in.reverse();
          }
          return out;
        };
    
        test(f, "Hello!");
        System.out.println(g.apply(new StringBuilder("Hello!")));
      }
    
      static void test(BiConsumer<StringBuilder,StringBuilder> f, String txt) {
        StringBuilder result = new StringBuilder();
        f.accept(new StringBuilder(txt), result);
        System.out.println(result);
      }
    }
    

    Olivier Grégoire

    Posted 2016-09-15T03:00:42.067

    Reputation: 10 647

    0

    Swift 2.2 127 bytes

    let x={(s:String) in var b = "";for var i in 1...s.characters.count {b += i%2==1 ?s:String(s.characters.reverse());};print(b);}
    

    unGolfed

    let x={(s:String) in
      var b = "";
      for var i in 1...s.characters.count {
        b += i%2==1 ?s:String(s.characters.reverse());
      };
      print(b);
    }
    

    Danwakeem

    Posted 2016-09-15T03:00:42.067

    Reputation: 141

    1{s in print((0..<s.characters.count).map{$0%2==0 ?s:String(s.characters.reverse())}.joinWithSeparator(""))} – Lotte Tortorella – 2016-09-17T11:15:37.943

    0

    PHP, 54 bytes

    while($c++-strlen($s=$argv[1]))echo$c%2?$s:strrev($s);
    

    I thought of this one myself before looking at other people's answers and then realised it's pretty much a combination of Crypto's and Titus' solutions... Well, I wanted to post it anyway :-)

    Christallkeks

    Posted 2016-09-15T03:00:42.067

    Reputation: 377

    0

    Python 3, 84 70 67 characters

    def s(d,i=1):
     t=d[::(i%2)*2-1]
     if i<len(d):t+=s(d,i+1)
     return t
    

    vpzomtrrfrt

    Posted 2016-09-15T03:00:42.067

    Reputation: 201

    You can insert r+=... to the same line as the for loop. – Yytsi – 2016-09-18T15:32:03.427

    (i%2)*4-1 is the same as i*2%4-1. – Post Rock Garf Hunter – 2016-09-19T01:40:41.933

    Try s=lambda d,i=0:d[::1-i*2%4]+s(d,i+1)if d[i:]else"" – Post Rock Garf Hunter – 2016-09-19T02:42:46.490

    You could also do s=lambda d,i=0:d+s(d[::-1],i+1)if d[i:]else"" but that really changes the algorithm. – Post Rock Garf Hunter – 2016-09-19T02:52:24.283

    0

    VBScript, 88 bytes

    a=WScript.Arguments(0)
    For i=1 To Len(a)
    WScript.StdOut.Write a
    a=StrReverse(a)
    Next
    

    Note: This does require the script execute using cscript.exe. For example...

    cscript.exe rev.vbs Hello!
    

    jveazey

    Posted 2016-09-15T03:00:42.067

    Reputation: 101

    -1

    C++ (gcc), 91 bytes

    void f(string s){ for(int i = 0; i++ < s.size(); reverse(s.begin(), s.end())) cout << s;  }
    

    Try it online!

    Ver Nick says Reinstate Monica

    Posted 2016-09-15T03:00:42.067

    Reputation: 555

    2

    You could remove those abundant whitespace... But how are you able to use string functions and cout without including them in your code?

    – None – 2019-12-04T13:36:34.530