I guess to simplify it, I would filter the possibilities at each step. first digit divisible by 1: N1=: 1+i.9
Second digit divisible by 2: N2=: ;(10*N1)+each (<2*1+i.4)-.each N Third digit divisible by 3: digits=: 10&#.inv N3=: (#~ 0=3|]);(10*N2)+each (<1+i.9) (-. digits) each N2 And, so on... and since we're basically doing the same thing at each step, we could encapsulate and parameterize this step as a function. F=: {{(#~ 0=x|]);(10*y)+each (<N1) (-. digits) each y}} 9 F 8 F 7 F 6 F 5 F 4 F 3 F 2 F N1 381654729 timespacex '9 F 8 F 7 F 6 F 5 F 4 F 3 F 2 F N1' 0.0006679 38400 So that took about a millisecond of machine time on this little laptop. Further simplifications are possible, but since this is a one use calculation this is probably good enough. -- Raul On Sun, Sep 10, 2023 at 2:02 PM 'Skip Cave' via Programming <programm...@jsoftware.com> wrote: > > Quora Question: Can you arrange the digits 1-9 to make a nine-digit number > such that the first digit is divisible by one, the first two digits are > divisible by two, the first three divisible by three and so on? > > My solution: > ea=.&.> > > at=.>10#.ea(a=.362880 9$1 to 9){.ea{n=.>:perm 9 > > {:"1 at#~*./"1[0=a|"1 at > > 381654729 > > > The answer is 381654729. > > > Check: > > ]m=.>10#.ea(;/1 to 9){.ea{sep 381654729 > > 3 38 381 3816 38165 381654 3816547 38165472 381654729 > > (1 to 9)| m > > 0 0 0 0 0 0 0 0 0 > > > There is only one answer. Is there a way to simplify or minimize the big > repetitive array 'a' to make the two J code lines more memory efficient & > succinct? > > > Skip Cave > Cave Consulting LLC > ---------------------------------------------------------------------- > For information about J forums see http://www.jsoftware.com/forums.htm ---------------------------------------------------------------------- For information about J forums see http://www.jsoftware.com/forums.htm