Sequências de dígitos decrescentes

16

Introdução

Como exemplo, vamos pegar o número 7. Em seguida, duplicamos isso e colocamos 7 espaços no meio. Temos isso:

7_______7

Depois disso, vamos diminuir o número, até que não haja mais espaços. Temos o seguinte para o número 7:

7_______7    
 6543210

Em seguida, apenas mesclamos os dois, portanto:

7_______7    
 6543210  becomes

765432107

Isso produzirá saída para N = 7 .

Parece fácil, certo? Agora vamos pegar N = 12 . Novamente inserimos 12 espaços entre os dois números, o que nos dá:

12____________12

Então começamos o decremento:

12____________12
  111098765432

E isso finalmente nos dá:

1211109876543212

Como você pode ver, a parte descendente termina em 2, não em 0 .

Tarefa

Dado um número inteiro maior que 1 , imprima a sequência descendente como mostrado acima.

Casos de teste

Input   Output

2       2102
3       32103
4       432104
5       5432105
6       65432106
7       765432107
8       8765432108
9       98765432109
10      10987654321010
11      111098765432111
12      1211109876543212
13      13121110987654313
14      141312111098765414
15      1514131211109876515
20      201918171615141312111020
99      9998979695949392919089888786858483828180797877767574737271706968676665646362616059585756555453525150499
100     1009998979695949392919089888786858483828180797877767574737271706968676665646362616059585756555453525150100

Isso é , então a submissão com o menor número de bytes vence!

Adnan
fonte
O espaço interno deve ser preenchido com números inteiros ou devemos cortar números, se necessário? Não há um caso de teste que cerca de (por exemplo 99)
edc65
@ edc65 Você deve cortar os números, se necessário. Eu adicionei 99 como um caso de teste.
Adnan

Respostas:

8

CJam, 11 10 bytes

q4*~,W%s<\

Experimente online. Supõe que há uma nova linha à direita na entrada. (Obrigado a @ jimmy23013 por salvar um byte.)

Explicação

No final de cada linha está a aparência da pilha nesse ponto (usando 4como exemplo).

q4*  e# Push input x 4 times, separated by newlines. ["4\n4\n4\n4\n"]
~    e# Evaluate, separating the 4's and converting them to numbers. [4 4 4 4]
,W%  e# Take the range of x and reverse it. [4 4 4 [3 2 1 0]]
s<   e# Cast to string and take the first x characters. [4 4 "3210"]
\    e# Swap the top two to get the final result. [4 "3210" 4]
NinjaBearMonkey
fonte
9

Julia, 30 bytes

n->"$n"join(n-1:-1:0)[1:n]"$n"

Esta é uma função anônima que aceita um número inteiro e retorna uma string. Para chamá-lo, atribua-o a uma variável.

Construímos e juntamos a sequência descendente de n -1 a 0 e pegamos os primeiros n caracteres da sequência resultante. Anexamos e anexamos isso com a entrada como uma string.

Verifique todos os casos de teste online

Alex A.
fonte
5

Haskell, 44 bytes

s=show
f n=s n++take n(s=<<[n-1,n-2..])++s n

Exemplo de uso: f 14-> "141312111098765414".

nimi
fonte
5

JavaScript (ES6), 55 52 bytes

n=>n+[...Array(m=n)].map(_=>--m).join``.slice(0,n)+n

Editar: salvou 3 bytes graças a @WashingtonGuedes.

Neil
fonte
@WashingtonGuedes Bah, eu nunca pareço usar .keys().
Neil
.keys()é como .reduce. A ferramenta certa para o trabalho, mas você sempre encontrar algo que pode fazer melhor, nesse caso específico
edc65
4

Python 2, 82 72 58 53 bytes

lambda x:`x`+''.join(map(str,range(x)[::-1]))[:x]+`x`

Experimente aqui!

Agradeço ao @Alex por me ensinar isso repr(x)= `x`economizando um monte de bytes!

Denker
fonte
3

Pitão, 11 bytes

++Q<jk_UQQQ

Duas versões alternativas, todas com 11 bytes ( suspiro ):

s[Q<jk_UQQQ
pQp<jk_UQQQ
  Q           the input
       UQ     [0, 1, ..., input-2, input-1]
      _       reverse
    jk        join on empty string
   <     Q    first (input) characters
          Q   the input again
++            concatenate everything so it prints on one line

Experimente aqui.

Maçaneta da porta
fonte
3

Japonês, 13 bytes

U+Uo w ¬¯U +U

Teste online!

Como funciona

               // Implicit: U = input integer
  Uo           // Create the range [0..U).
     w         // Reverse.
       ¬       // Join.
        ¯U     // Slice to the first U chars.
U+         +U  // Append U on either end.
ETHproductions
fonte
3

Gelatina, 10 bytes

Ȯ’r0DFḣ³Ḍ³

Experimente online!

Como funciona

Ȯ’r0DFḣ³Ḍ³  Main link. Input: n

Ȯ           Print n.
 ’          Decrement to yield n - 1.
  r0        Create a range from n - 1 to 0.
    D       Convert each integer to base 10 (array of decimal digits).
     F      Flatten the resulting array.
      ḣ³    Keep the first n elements.
        Ḍ   Convert from base 10 to integer.
         ³  Print the integer and set the return value to n.
            (implicit) Print the return value.
Dennis
fonte
2

Vitsy, 35 bytes

Como Vitsy não está ciente de como fazer seqüências de caracteres com números, eu implementei encontrando o comprimento do número em casas decimais na segunda linha.

V0VVNHVv[XDN1mv$-DvD);]VN
1a/+aL_1+

Explicação:

V0VVNHVv[XDN1mv$-DvD);]VN
V                          Save the input as a global final variable.
 0V                        Push 0, push input.
   VN                      Output the input.
     H                     Push the range 0...intput.
      Vv                   Push the input, then save it as a temp variable.
        [             ]    Do the stuff in brackets infinitely or until exited.
         X                 Remove the top item of the stack.
          DN               Duplicate, then pop as output.
            1m             Calls the first line index, retrieving length.
              v            Pop the temp var and push it to the stack.
               $           Switch the top two items of the stack. 
                -          Subtract them.
                 Dv        Duplicate, then pop one as a temp var.
                   D);     If it's zero, exit the loop.
                       VN  Output the global var.

1a/+aL_1+
1a/+       Add .1. This makes sure we don't throw errors on input 0.
    a      Push ten.
     L     Pop the top item as n, push the log base n of second to top.
      _    Make it an int.
       1+  Add 1.

Experimente Online!

Modo detalhado para risos:

save top as permanent variable;
push 0;
save top as permanent variable;
save top as permanent variable;
output top as number;
push all ints between second to top and top;
save top as permanent variable;
save top as temporary variable;
begin recursive area;
remove top;
duplicate top item;
output top as number;
push 1;
goto top method;
save top as temporary variable;
switch the top two items;
subtract top two;
duplicate top item;
save top as temporary variable;
duplicate top item;
if (int) top is not 0;
generic exit;
end recursive area;
save top as permanent variable;
output top as number;
:push 1;
push 10;
divide top two;
add top two;
push 10;
push ln(top);
replace top with int(top);
push 1;
add top two;
Addison Crump
fonte
Parece que o modo detalhado está errado em sua definição de L, corrigindo isso agora (embora não atualize a pergunta).
Addison Crump
Apenas curioso, como você evita que o método seja executado no final do programa? O caractere de nova linha é um sinal para retornar / sair do programa?
LegionMammal978 27/02
@ LegionMammal978 Imagine que a primeira linha de todo programa Vitsy é o método "principal", e todas as outras linhas são public static voidmétodos. O principal termina o programa quando terminar. Quanto a como isso é feito, as instruções são mantidas em um tipo ArrayList<ArrayList<String[]>>, onde cada linha é a String[]. Cada método é dividido na nova linha de acordo com a forma como o arquivo é carregado, fazendo com que o método principal seja separado de todos os outros métodos.
Addison Crump
Isso explica por que são necessários três níveis. Então, Strings são instruções, String[]s são métodos (o primeiro é o método principal) e ArrayList<String[]>s são classes (o primeiro é a classe principal), correto?
LegionMammal978 27/02
@ LegionMammal978 Está tudo correto. :)
Addison Crump
2

Pure Bash, 49

eval printf -va %s {$[$1-1]..0}
echo $1${a::$1}$1

Ou:

Bash + coreutils, 48

echo $1$(seq $[$1-1] -1 0|tr -d \\n|head -c$1)$1
Trauma Digital
fonte
Não tenho certeza de que estão avaliando o intervalo corretamente. Após o teste, ambos imprimem apenas metade da faixa. ou seja, para $ 1 = 90, o intervalo é apenas de 45. Meu esforço foi "para i em $ (eval echo {$ 1..0}); faça eco -n $ i; pronto; eco $ 1"
rcjohnson
@ rcjohnson Acho que esse é o comportamento necessário. O que você espera que a saída seja para N = 90?
Digital Trauma
@rcjohnson, por exemplo, para N = 12, a saída deve ser 12, os primeiros 12 caracteres de 11..0(ou 111098765432) e, finalmente,12
Trauma Digital
Bem, ao reler a descrição, vejo que você está correto. O problema indica "espaços" e não números inteiros.
Rcjohnson 27/02
@rcjohnson Sim, acho que a parte "spaces" se aplica apenas a etapas intermediárias. A saída final deve ser apenas uma sequência de dígitos.
Digital Trauma
2

Retina, 63 bytes

.+
$0,y$0$*y$0$*x
x
$'_
(x)*_
$#1
+`(y+)y(.)
$2$1
,(\d+).*
$1$`

Ainda há bastante espaço para jogar golfe ...

Experimente online!

randomra
fonte
Hum, estou pensando em tornar o $0in $0$*opcional também, quando o token anterior é um literal que não é um número (como o seu ys) ... vendo isso, eu realmente posso implementar isso.
Martin Ender
@ MartinBüttner Eu pensei que era o novo recurso, mas acabou não sendo realmente. :)
randomra 27/02
Não, atualmente isso só funciona no início da substituição. Dito isto, talvez você possa mudar os papéis do primeiro e do último número para fazer uso disso?
Martin Ender
2

MATL , 15 bytes

VG:qPVXvG:)GVhh

EDIT (20 de maio de 2016) O código no link usa Xz vez de Xv, devido a alterações recentes no idioma.

Experimente online!

V                 % input n. Convert to string
 G:               % range [1,2,...,n]
   qP             % convert into [n-1,n-2,...,0]
     VXv          % convert to string, no spaces
        G:)       % take first n characters only
           GV     % push input as a string, again
             hh   % concat horizontally twice    
Luis Mendo
fonte
1

Java, 93 bytes

String x(int v){String o=""+v;for(int i=v-1,c=o.length();o.length()-c<v;i--)o+=i;return o+v;}
Addison Crump
fonte
1

Ruby, 41 bytes

->n{[n]*2*(r=0...n).to_a.reverse.join[r]}
úmido
fonte
1

Via Láctea 1.6.5 , 27 25 bytes

I'::%{K£BCH=}<ΩHG<+<;+!

Explicação

I                        ` empty the stack
 '::                     ` push 3 copies of the input
    %{K£BCH=}            ` dump digits of reversed range(n) as strings [n-1...0]
             <ΩHG<+<;+   ` select the first nth digits and pad them with n
                      !  ` output

Uso

$ ./mw <path-to-code> -i <input-integer>
Zach Gates
fonte
Qual codificação a Via Láctea usa?
Adnan
Uhhh .. UTF-8, eu acho haha. @AandN
Zach Gates
Eu recebi esse erro (sim, sou um babaca do Windows: p) ao tentar executá-lo. Eu colei isso: I'::%{K£BCH=}<OHG<+<;+!em um arquivo codificado em UTF-8, mas não funciona.
Adnan
Aqui está um link para o arquivo que estou usando. @AandN
Zach Gates
1

Perl 6 , 31 bytes

{$_~([R~] ^$_).substr(0,$_)~$_}
{
  $_ # input
  ~  # string concatenated with
  ([R~] ^$_)    # all numbers up to and excluding the input concatenated in reverse
  .substr(0,$_) # but use only up to the input number of characters
  ~
  $_
}

Uso:

for 2,3,7,12,100 {
  say {$_~([R~] ^$_).substr(0,$_)~$_}( $_ )
}
2102
32103
765432107
1211109876543212
1009998979695949392919089888786858483828180797877767574737271706968676665646362616059585756555453525150100
Brad Gilbert b2gills
fonte
1

Perl, 43 + 2 = 45 bytes

Estou feliz por não ter usado reversee nem substr:

"@{[1-$_..0]}"=~s.\D..gr=~/.{$_}/;$_.=$&.$_

Requer as -plbandeiras.

$ perl -ple'"@{[1-$_..0]}"=~s.\D..gr=~/.{$_}/;$_.=$&.$_' <<< 12
1211109876543212

Como funciona:

                                            # '-p' read first line into `$_` and
                                            # auto print at the end
"@{[1-$_..0]}"                              # Create a list from -1-n..0 and
                                            # join it on space. This becomes:
                                            #   "-11 -10 -9 -8 -7 -6 -5 -4 -3 -2 -1 0"
              =~s.\D..gr                    # Remove all but digits:
                                            #   "11109876543210"
                        =~/.{$_}/;          # Match the n first characters from
                                            # the generated string
                                  $_.=$&.$_ # Append the match and the input
andlrc
fonte
1

C, 130 125 bytes

#define p(x) printf("%i",x);
i,y,h;f(x){for(i=y=x;(i-=h)>=0;){p(y--)h=floor(log10(y))+1;}if(i+=h)p(h=floor(y/pow(10,i)))p(x)}

Versão não destruída (com explicação):

#define p(x) printf("%i",x);     // alias to print an integer
i,y,h;                           // helper variables
f(x){                            // function takes an integer x as arg
    for(i=y=x;(i-=h)>=0;){       // i -> the remaining space
                                 // y -> the current descending number
        p(y--)                   // print y (at first y==x)
        h=floor(log10(y))+1;     // h -> the number of digits in y-1
    }                            // do it until there is no more empty space
    if(i+=h)                     // if needs to chop the last number
        p(h=floor(y/pow(10,i)))  // chop and print (implicitly cast of double to int)
    p(x)                         // print x at the end
}                                // end function

A conversão implicitamente de double para int in h=floor(...)permitiu o uso de #define p(x)salvar 5 bytes.

Teste em ideona.

removido
fonte
1

R, 67 bytes (como função)

# usage example : f(7)
f=function(i)cat(i,substr(paste((i-1):0,collapse=''),1,i),i,sep='')

R, 63 bytes (entrada de STDIN)

i=scan();cat(i,substr(paste((i-1):0,collapse=''),1,i),i,sep='')
digEmAll
fonte
1

Brainfuck, 265 bytes

Isso só funciona com números <10

Experimente a versão golfada aqui :

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

Ungolfed. Experimente aqui :

>
,
---------- Convert to base 10
----------
----------
----------
-------- 


[->+>+<<]>>[-<<+>>]<

Fill up the grid
[
[->+>+<<]>>[-<<+>>] //duplicate number like [5][0] -> [5][5]
<-
]

<[<]> Go to cell 1
[

>[>] Scan for zero
> Move one more
+ Add one
<< Move two back
[<] Scan for zero
> Move one forward
- Subtract One
]

> Move one forward into actual numbers
[
++++++++++ Convert to ascii
++++++++++
++++++++++
++++++++++
++++++++
.
>
]
++++++++++ Convert to ascii
++++++++++
++++++++++
++++++++++
++++++++
.
>
++++++++++ Convert to ascii
++++++++++
++++++++++
++++++++++
++++++++
.
Keatinge
fonte
,>>++++++[<++++++++>-]<[-<->]<Isso pode subtrair 48 com comprimento de código mais curto
Leaky Nun