Alfabe şifresini kodla


24

Yalnızca küçük harf içeren bir dize verildiğinde, bu dizeyi alfabe şifresiyle kodlayın.

Alfabe şifresi ile kodlamak için (örneği kullanacağım hello):

  1. İlk olarak, dizedeki her harfi alfabedeki konumuna göre bir sayıya dönüştürün ( a= 1, b= 2, vs.)8 5 12 12 15
  2. Her sayıyı 0s ile iki karaktere getirin . Örnek:08 05 12 12 15
  3. Katılmak. Örnek:0805121215

Test durumları

helloworld -> 08051212152315181204
codegolf -> 0315040507151206
alphabetcipher -> 0112160801020520030916080518
johncena -> 1015081403051401

Unutmayın, bu , bu yüzden en az bayt sayısına sahip olan kod kazanır.


Yanıtlar:


23

05AB1E , 11 6 bayt

Kod:

Ç4+€¦J

Açıklama:

İlk olarak, dizeyi ASCII değerlerine dönüştürürüz. codegolfolacaktı:

[99, 111, 100, 101, 103, 111, 108, 102]

Alfabenin indekslerine ulaşmak için, çıkartın 96:

[3, 15, 4, 5, 7, 15, 12, 6]

Sıfırlarla doldurmak için, 100her bir öğeye ekleyin ve her int'nin ilk karakterini kaldırın. Yukarıdaki örnek için, +100şöyle olurdu:

[103, 115, 104, 105, 107, 115, 112, 106]

Ve her birinin ilk karakterini kaldırmak:

[03, 15, 04, 05, 07, 15, 12, 06] 

Yukarıdaki ( -96ve +100) bölümlerinin her ikisini de sadece bir araya getirebiliriz +4. Kod için:

Ç       # Convert to an array of ASCII code points
 4+     # Add four to each element in the array
   €¦   # Remove the first character of each element
     J  # Join to a single string

Çevrimiçi deneyin!


¦Tekrar ne yapar ?
Magic Octopus Urn

@carusocomputing Bir dizgenin, listenin vs. ilk elemanını kaldırır.
Adnan

Dâhinin Ötesinde ...
Magic Octopus Urn

12

Python 2,42 bayt

f=lambda s:s and`ord(s[0])+4`[1:]+f(s[1:])

İdeone üzerinde test et .


5
Özyinelemeli olmayan, aynı bayt sayısı:lambda s:''.join(`ord(x)+4`[1:]for x in s)
Jonathan Allan

8

Pyth, 11 10 bayt

FNwpt`+4CN

Dene! İlk adım Pyth'a gitti.

FNwpt`+4CN
FNw         # For N in w (w is input, N will be single char)
   p        # Print without newline
        CN  # Int with code point `N`
      +4CN  # Add 4 to int with code point N
     `+4CN  # representation of above (basically to string)
    t`+4CN  # Tail (All but first character)

Python eşdeğeri:

for N in input():
    print(repr(ord(N) + 4)[1:], end='')

İlk Pyth programında iyi iş çıkardın!
HyperNeutrino,

7

C, 55 43 bayt

f(char*c){for(;*c;)printf("%02d",*c++-96);}

ideone


1
printf("%02d",*c++-96);}yanılmıyorsam daha kısa ve geçerlidir.
Dada

6

Python, 46 bayt

lambda x:"".join("%02i"%(ord(j)-96)for j in x)

Oldukça basit. Tekrar dene!


1
Vay, aynı byte sayısı ile iki tamamen farklı girişimler;)
Kade

6

Jöle , 9 7 bayt

O+4ṾḊ$€

TryItOnline

Nasıl?

O+4ṾḊ$€ - Main link: s                                e.g. hello
O       - cast to ordinals                            e.g. [ 104,  101,  108,  108,  111]
 +4     - add 4                                       e.g. [  108,  109,  112,  112,  115]
     $€ - last two links as a monad for €ach
   Ṿ    -    uneval, effectively converts to strings  e.g. ["108","109","112","112","115"]
    Ḋ   -    dequeue, remove the leading '1'          e.g. [ "08", "09", "12", "12", "15"]
        - implicit print                              e.g. "0809121215"

O+4DḊ€FṾ€Aynı sayıya geldim , belki golf oynayabilirim
ETHproductions

@ETHproductions O+4Ṿ€Ḋ€2 bayt kaydeder.
Dennis,

@Dennis Ben sadece aynısını yaptım (ish) ...
Jonathan Allan

4

Haskell, kırk dört 30 28 bayt

(>>=tail.show.(+4).fromEnum)

Adnan'ın cevabındaki+4 yaklaşımı kullanarak 14 bayt kazandırır.

Ideone'da dene. Kullanımı:

> (>>=tail.show.(+4).fromEnum)"codegolf"
"0315040507151206"

Xnor sayesinde iki bayt kapalı . Eski versiyon:

f a=['0'|a<'k']++(show$fromEnum a-96)
(f=<<)

İkinci grup parene ihtiyacın yok.
xnor

3

Perl, 29 bayt

28 bayt kodu + -nbayrak.

printf"%02s",-96+ord for/./g

Çalıştır:

perl -ne 'printf"%02s",-96+ord for/./g' <<< "helloworld"

3

JavaScript (ES6), 52 49 bayt

f=s=>s&&(s.charCodeAt()+4+f(s.slice(1))).slice(1)

Özyineleme şunun 3 bayttan daha kısa olduğu ortaya çıktı .replace:

s=>s.replace(/./g,s=>(s.charCodeAt()+4+"").slice(1))

parseInt(s,36)Eğer değişim bulunması gerektiğinden, her yaklaşım için biraz daha uzun olduğu 4için 91:

s=>s.replace(/./g,s=>(parseInt(s,36)+91+"").slice(1))
f=s=>s&&(parseInt(s[0],36)+91+f(s.slice(1))).slice(1)

3

Japt, 10 bayt

¡4+Xc)s s1

Muhtemelen bundan daha kısa olmaz ...

Çevrimiçi test edin!

açıklama

¡           // Map each char X in the input by this function:
 4+Xc)      //   Take 4 + the char code of X.
      s s1  //   Convert to a string, then remove the first char.
            // Implicit: output last expression



3

Altıgen , 33 bayt

10}{'a({=!{{\.@29$\,<.-":!\>Oct\%

Çevrimiçi Deneyin!

Mm .. Altıgende birkaç tane operasyon yok, bu yüzden bugünün tarihini belirledim.

No-ops ile değiştirilen tarih içeren genişletilmiş Form

   1 0 } {
  ' a ( { =
 ! { { \ . @
. . $ \ , < .
 - " : ! \ >
  . . . \ %
   . . . .
  1. A başlatıyın 10ve Bellek İşaretçisini bir yere taşıyın ...
  2. $yansıtmayı atlar ve ,bir bayt okur. <dallar:
  3. Eğer dizgenin sonu ( -1pozitif olmayan)@ programa ve sonlandırır.
  4. Aksi halde çıkarır 95(azalır a) ve sonra yazdırır result / 10(tam sayı bölme) ve result % 10tekrar döngü.

2

Vim, 60 tuş vuruşlarını

:s/./\=char2nr(submatch(0))-96."\r"/g
:%s/\<\d\n/0&
V{gJ

Bir neredeyse tamamen normal ifade göre çözelti. Her zamanki gibi, değerlendirme kaydını kullanmak onu müstehcen şekilde uzun yapar.



2

PowerShell v2 +, 44 bayt

-join([char[]]$args[0]|%{"{0:D2}"-f($_%32)})

Girdiyi alır $args[0], bir chardizi olarak atar, bir döngüye girer. Her yinelemede, ASCII değeri olarak örtüşen mevcut karakter $_modülünü alırız 32. Uygun bir şekilde ;-), bu a = 1, b = 2şekilde -fsıralanır , vb "{0:D2}". Bu rakam dizileri parantez -joiniçine alınmış, bir dizgede bir araya getirilmiş ve boru hattında bırakılmıştır. Örtülü çıktı Write-Output, programın sonunda olur.

PS C:\Tools\Scripts\golfing> .\encode-alphabet-cipher.ps1 'hello'
0805121215

PS C:\Tools\Scripts\golfing> .\encode-alphabet-cipher.ps1 'helloworld'
08051212152315181204

PS C:\Tools\Scripts\golfing> .\encode-alphabet-cipher.ps1 'codegolf'
0315040507151206

PS C:\Tools\Scripts\golfing> .\encode-alphabet-cipher.ps1 'johncena'
1015081403051401

2

Perl, 24 bayt

İçin +1 içerir -p

STDIN'e giriş verin:

encode.pl <<< hello

encode.pl

#!/usr/bin/perl -p
s/./substr 4+ord$&,1/eg

Güzel bitti. Sanırım muhtemelen 4+ord$&bunun yerine demek 5+ord$&
Dada 8

@Dada Sağ, test edilen sürüm yerine snippet arabelleğimin sürümünü tekrar yapıştırdı
Ton Hospel

Olur! :) Size ilgisiz bir soru sorabilir miyim? Bu sorunun 8 baytlık perl çözümünün ne olduğu hakkında bir fikriniz var mı (girişi tersine çevirir) (anarşide)?
Dada

@Dada saf perl'de imkansız olduğunu söyleyebilirim, bu yüzden o taraftaki otomatik sistemin biraz kötüye kullanılmasını bekliyorum. Örneğin, girdi exec rev
STDIN'den

Doğru, bu mantıklı, teşekkürler! print5 byte, <>2 tane daha olduğu için bunu anlamakta zorlanıyordum , bu yüzden duymadığım 1 byte yerleşikinin ne olduğunu merak ediyordum!
Dada

2

DASH , 27 bayt

@><""(->@rstr["."""]+4#0)#0

Örnek kullanım:

(@><""(->@rstr["."""]+4#0)#0)"helloworld"

açıklama

@ (                         #. take input through a lambda
  join "" (                 #. join with newlines the following:
    (map                    #. result of mapping
      @ (                   #. this lambda
        rstr ["." ; ""] (     #. replace first char w/ empty string:
          + 4 #0               #. mapped item's codepoint + 4
        )
      )
    ) #0                    #. over the argument
  )
)

2

Toplu iş, 256 239 237 bayt

@echo off
set/ps=
set r=
set a=abcdefghijklmnopqrstuvwxyz
:g
set c=%a%
for /l %%i in (101,1,126)do call:l %%i
set s=%s:~1%
if not "%s%"=="" goto g
echo %r%
exit/b
:l
set i=%1
if %c:~,1%==%s:~,1% set r=%r%%i:~1%
set c=%c:~1%

STDIN'de girişi ele alır.


2

IBM PC DOS 8088 Düzeneği, 33 28 27 bayt

Montajlı ikili:

00000000: be82 00ac 2c60 7812 d40a 0530 3092 86f2  ....,`x....00...
00000010: b402 cd21 86f2 cd21 ebe9 c3              ...!...!...

unassembled:

BE 0082     MOV  SI, 82H        ; point SI to command line string 
        CH_LOOP: 
AC          LODSB               ; load next char into AL
2C 60       SUB  AL, 'a'-1      ; convert ASCII to a=1,b=2...z=26 
78 12       JS   DONE           ; if char is terminator or not valid, exit
D4 0A       AAM                 ; convert binary to BCD 
05 3030     ADD  AX, '00'       ; convert BCD to ASCII 
92          XCHG DX, AX         ; save AX to DX for display 
86 F2       XCHG DH, DL         ; reverse bytes 
B4 02       MOV  AH, 2          ; DOS display char function 
CD 21       INT  21H            ; write first digit 
86 F2       XCHG DH, DL         ; reverse bytes back 
CD 21       INT  21H            ; write second digit 
EB E9       JMP  CH_LOOP        ; restart loop 
        DONE: 
C3          RET                 ; return to DOS

Bağımsız PC DOS çalıştırılabilir. Komut satırından dize girdi, konsola çıktı.

I / O:

enter image description here


1

MATL , 11 bayt

96-OH&YA!1e

Çevrimiçi deneyin!

         % Implicit input
96-      % Subtract 96. So 'a' becomes 1, 'b' becomes 2 etc
OH&YA    % Convert each number to 2 decimal digits. Gives a 2-column matrix
!1e      % Transpose and linearize into a row
         % Implicit display

1

Ruby, 53 46 bayt

->s{s.chars.map{|c|(c.ord-96).to_s.rjust(2,?0)}.join}

->s{s.chars.map{|c|(c.ord+4).to_s[1..2]}.join}


1

R, 71 51 bayt

Billywob sayesinde 20 byte kurtarıldı. Stdin'den girdi alır ve stdout'a çıktılar.

cat(sprintf("%02d",utf8ToInt(scan(,""))-96),sep="")

Örnekler:

helloworld -> 08051212152315181204

codegolf -> 0315040507151206

alfabe kodlayıcısı -> 0112160801020520030916080518

johncena -> 1015081403051401


utf8toInt(scan(,"))-96Bütün eşleşme yerine kullanabilirsiniz . Dolgu ile başa çıkmak için daha iyi bir yol olduğunu sanmıyorum.
Billywob 29:16,

@Billywob Teşekkürler! Dolgu için formatCdaha önce kullanmaya çalıştım, fakat mevcut yaklaşımdan bir bayta daha ihtiyaç duyuyordu.
rturnbull

1

Aslında 10 bayt

Adnan'ın 05AB1E cevaplarında düzgün algoritmanın kullanılması . Golf önerileri kabul edilir. Çevrimiçi deneyin!

O4+`$pX`MΣ

Ungolfing

         Implicit input s.
O        ord() every char in s.
4+       Add 4 to every ord in s.
`...`M   Map the following function over s. Variable m.
  $        Push str(m).
  pX       Discard the first char of str(m).
           Invariably this is a `1` and we get our ciphered m.
Σ        sum() everything to get one string.
         Implicit return.





0

Pyke, 7 bayt

F.oOO`t

Burada dene!

F       -  for i in input:
 .o     -       ord(i)
   OO   -      ^ + 4
     `  -     str(^)
      t -    ^[1:]
        - sum(^)

Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.