Ah yes, better!
Works on the five test cases :-)

On Thu, 4 Feb 2021 at 23:13, Ric Sherlock <tikk...@gmail.com> wrote:

> Thanks, yes that works!
> Here's a slightly simpler take on the same approach:
> {{ ((+ idx&<)#y) {. y ({. ,'X', }.)~ idx =. >:+: 1 i.~ (=/"1) _2 ]\y }}^:_
>
> On Thu, Feb 4, 2021 at 8:48 PM Ben Gorte <bgo...@gmail.com> wrote:
>
> > Think I've got it:
> >
> > data1 =: 'THEEQUICKBROWFFOX'
> >
> > data2 =: 'THEEQUICKBROWFOOX'
> >
> > {{ ((+where&<)#y) {. ({.&y ,'X', }.&y) where =. >: +: 1 i.~ _2 =/\
> > y,'XX',(2|#y){.'X' }}^:_ data1
> >
> > THEXEQUICKBROWFXFOX
> >
> > {{ ((+where&<)#y) {. ({.&y ,'X', }.&y) where =. >: +: 1 i.~ _2 =/\
> > y,'XX',(2|#y){.'X' }}^:_ data2
> >
> > THEXEQUICKBROWFOOX
> >
> >
> > Ben
> >
> > On Thu, 4 Feb 2021 at 17:02, Hauke Rehr <hauke.r...@uni-jena.de> wrote:
> >
> > > I show this only as a different way to deal with it.
> > > There’s much space for improvement.
> > > It works correctly with the two examples you gave.
> > >
> > > data1 =: 'THEEQUICKBROWFFOX'
> > > data2 =: 'THEEQUICKBROWFOOX'
> > > res1  =: 'THEXEQUICKBROWFXFOX'
> > > res2  =: 'THEXEQUICKBROWFOOX'
> > >
> > > s =: 2 : 0
> > > a =. 0 -.~ (* i.@#) m=y
> > > n a} y
> > > )
> > >
> > > NB. ugly, repetitive junk solution
> > > res1 = ('?'s'X') (] (>:@(+ i.@#)@(2 I.@:=]) (([e.~i.@#@]){"0 1'X',.~])
> > > #~) (i.@# >:@e. (* -.@(- (0 1 $~ $))@(2&|))@(-.&0@(*
> > > i.@#))@(2&(=/@|:@]\)))) ('X's'?') data1
> > > res2 = ('?'s'X') (] (>:@(+ i.@#)@(2 I.@:=]) (([e.~i.@#@]){"0 1'X',.~])
> > > #~) (i.@# >:@e. (* -.@(- (0 1 $~ $))@(2&|))@(-.&0@(*
> > > i.@#))@(2&(=/@|:@]\)))) ('X's'?') data2
> > >
> > >
> > > Am 04.02.21 um 05:02 schrieb Ric Sherlock:
> > > > I need to separate any digraphs in a string, that consist of 2
> letters
> > > the
> > > > same, by inserting an 'X' between them.
> > > >    _2 ]\ 'THEEQUICKBROWFFOX'
> > > > TH
> > > > EE
> > > > QU
> > > > IC
> > > > KB
> > > > RO
> > > > WF
> > > > FO
> > > > X
> > > >
> > > > 'EE' is a digraph that needs an 'X' inserted. Doing so will result
> in:
> > > >
> > > > TH
> > > > EX
> > > > EQ
> > > > UI
> > > > CK
> > > > BR
> > > > OW
> > > > FF
> > > > OX
> > > >
> > > > So now we also need to separate the 'FF' digraph.
> > > >
> > > > I want to define a verb "dedouble" that will process a string so:
> > > >    dedouble 'THEEQUICKBROWFFOX'
> > > > THEXEQUICKBROWFXFOX
> > > > But:
> > > >    dedouble 'THEEQUICKBROWFOOX'
> > > > THEXEQUICKBROWFOOX
> > > >
> > > > I have implemented a solution at
> > > > https://rosettacode.org/wiki/Playfair_cipher#J but am interested in
> > > > alternative implementations.
> > > >
> ----------------------------------------------------------------------
> > > > For information about J forums see
> http://www.jsoftware.com/forums.htm
> > > >
> > >
> > > --
> > > ----------------------
> > > mail written using NEO
> > > neo-layout.org
> > >
> > > ----------------------------------------------------------------------
> > > For information about J forums see http://www.jsoftware.com/forums.htm
> > >
> > ----------------------------------------------------------------------
> > For information about J forums see http://www.jsoftware.com/forums.htm
> >
> ----------------------------------------------------------------------
> For information about J forums see http://www.jsoftware.com/forums.htm
>
----------------------------------------------------------------------
For information about J forums see http://www.jsoftware.com/forums.htm

Reply via email to