Pamiętajcie o samogłosce!

25

Wkład

Ciąg znaków ASCII do wydruku, na przykład:

This is an example string.

Wydajność

Do każdej spółgłoski ( BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz), po której nie następuje samogłoska ( AEIOUaeiou), dodaj ostatnią samogłoskę przed nią małymi literami.
Spółgłoski przed pierwszą samogłoską pozostają bez zmian :

Thisi isi ana examapale seterinigi.

Przypadki testowe

AN EXAMPLE WITH A LOT UPPERCASE (plus some lowercase)
=> ANa EXAMaPaLE WITiHi A LOTo UPuPEReCASE (pelusu some lowerecase)

And here comes a **TEST** case with 10% symbols/numbers(#)!
=> Anada here comese a **TESeTe** case witihi 10% siyimiboloso/numuberese(#)!

This is an example string.
=> Thisi isi ana examapale seterinigi.

abcdefghijklmnopqrstuvwxyz
=> abacadefegehijikiliminopoqorosotuvuwuxuyuzu

A pnm bnn
=> A panama banana

Tell me if you need more test cases!
=> Telele me ifi you neede more tesete casese!

Punktacja

Ponieważ jest to , wygrywa odpowiedź o najniższej liczbie bajtów w każdym języku (żadna odpowiedź nie zostanie zaakceptowana).

pustkowie
źródło
Czy zatem wstawiane samogłoski powinny zawsze być pisane małymi literami, a tekst może być zarówno wielkimi, jak i małymi literami?
Erik the Outgolfer,
Czy dane wyjściowe mogą mieć postać listy / tablicy?
Nathan Dimmer
@EriktheOutgolfer Tak, nie chciałem wielkich liter tam, gdzie potrzebujemy małych liter, ale nadmiernie skomplikowałoby to wyzwanie, gdyby trzeba było sprawdzić przypadek sąsiednich liter
bez
11
Jedz zdrowe dzieci, spróbuj A pnm bnn!
Stewie Griffin
4
Czy ktoś jeszcze myśli, że „Jak Włosi” muszą gdzieś znaleźć się w tytule?
Artelius

Odpowiedzi:

14

Siatkówka , 48 bajtów

i`(?<=([aeiou]).*?[^\W\d_aeiou])(?![aeiou])
$l$1

Wypróbuj online! Objaśnienie: Lookahead szuka punktu, po którym nie następuje samogłoska, podczas gdy lookbehind szuka bezpośrednio poprzedzającej spółgłoski i poprzedniej samogłoski, która jest następnie wstawiana małymi literami.

Neil
źródło
8

JavaScript (ES6), 108 105 bajtów

(Zaoszczędź 3 bajty dzięki @Shaggy.)

f=s=>(t=(s+=' ').replace(/[aeiou]|[a-z][^aeiou]/ig,r=>r[1]?r[0]+v.toLowerCase()+r[1]:v=r,v=''))!=s?f(t):s

Wyszukuje samogłosek lub spółgłosek bez następującej samogłoski:

/[aeiou]|[a-z][^aeiou]/ig

(Nie musimy jawnie szukać spółgłosek, ponieważ samogłoski są wykluczane na podstawie /[aeiou]|....)

Samogłoski są przechowywane w v, i vwstawiono spółgłosek bez następującej samogłoski :

r[1]?r[0]+v.toLowerCase()+r[1]:v=r

(Jeśli r[1]istnieje, dopasowaliśmy spółgłoskę i samogłoskę).

Jeśli nic się nie zmieniło, zwracamy dane wejściowe. W przeciwnym razie powracamy do zastąpionego ciągu.

Rick Hitchcock
źródło
1
To jest jeszcze lepsze. Naprawdę muszę spojrzeć na regex
Luis Felipe De Jesus Munoz
+1 sprytny pomysł, aby użyć zamień na mapę + dołącz
Downgoat
Na podstawie twojej (prawie) działającej wersji bez rekurencji: s=>s.replace(/[aeiou][^a-z]*([a-z](?![aeiou]))+/gi,s=>s.replace(/(?!^)./g,a=>a+s[0].toLowerCase()))Wydaje mi się, że nie mam problemów z sekwencjami
nieliterowymi
Rekursja z pewnością upraszcza tutaj sprawy.
Rick Hitchcock,
(s+=' ')powinien zaoszczędzić kilka bajtów.
Shaggy
5

Python 2 , 134 119 bajtów

def f(s,v=''):u=s[:1];return s and u+v*(u.isalpha()-g(u)-g((s+u)[1]))+f(s[1:],[v,u.lower()][g(u)])
g='aeiouAEIOU'.count

Wypróbuj online!

EDYCJA: 15 bajtów dzięki Lynn

Chas Brown
źródło
Trochę się z tym bawiłem przez 119 bajtów .
Lynn
@ Lynn: Uwielbiam <vowels>.count.
Chas Brown,
4

Standardowy ML , 225 223 bajtów

str o Char.toLower;fun?c=String.isSubstring(it c)"aeiou"fun g(x,l)$d=(fn l=>if Char.isAlpha$andalso not(?d)then if? $then(it$,l)else(x,l^x)else(x,l))(l^str$)fun f$(c::d::r)=f(g$c d)(d::r)|f$[c]= #2(g$c c);f("","")o explode;

Wypróbuj online!

Mniej golfa:

val lower = str o Char.toLower

fun isVowel c = String.isSubstring (lower c) "aeiou"

(* c is the current char, d is the next char, x is the last vowel and l the accumulator 
   for the resulting string *)
fun g (x,l) c d = 
    if Char.isAlpha c andalso not (isVowel d)
    then if isVowel c 
         then (lower c, l^str c)
         else (x, l^str c^x)
    else (x, l^str c)

fun f t (c::d::r) = f (g t c d) (d::r)
  | f t [c] = #2(g t c #"d")

val h = f ("","") o explode;

Wypróbuj online!

Laikoni
źródło
wow, ML golf wygląda naprawdę interesująco! Uwielbiam iti używam $nazwy zmiennej.
Lynn
@ Lynn Napisałem poradę na temat zmiany nazwy identyfikatora jakiś czas temu i planowałem napisać o niej it, ale jeszcze się nie obejrzałem.
Laikoni
4

sed 4.2.2 , 64 bajty

:
s/(([aeiou])[^a-z]*[b-df-hj-np-tv-z])([^aeiou]|$)/\1\l\2\3/I
t

Wypróbuj online!

KernelPanic
źródło
Będę szczery, moim celem tutaj jest próba pokonania Perla o kilka bajtów. Zobaczmy, czy się trzyma :)
KernelPanic
4

Perl 5, 68 67 59 bajtów

perl -pe '$v="[aeiou])";1while s/($v[^a-z]*[b-z]\K(?<!$v(?!$v/\L$1/i'

Oto świetny przykład przydatności \Ki nie mogę uwierzyć, że nie wiedziałem o tej funkcji, zanim Dom Hastings zwrócił na to uwagę.

Nie byłem w stanie uzyskać prawidłowego zachowania po prostu przy użyciu s///g, więc faktyczna pętla wydaje się konieczna. (Możliwe jest, że prawidłowe użycie twierdzenia, które się spogląda, mogłoby działać bez wyraźnego określenia while- ale go nie znalazłem).

chlebak
źródło
Niezłe podejście! Nie udało się wymyślić nic lepszego, ale udało się pobrać 6 bajtów: Wypróbuj online!
Dom Hastings,
1
@DomHastings: Jeszcze krótszy (do 58 bajtów) poprzez dodanie [aeiou])do zmiennej: Wypróbuj online!
ShadowRanger,
3

JavaScript ES6, 115 bajtów

Oszczędza 8 bajtów dzięki @ETHProductions

s=>[x="",...s].map((i,j)=>(r=/[aeiou]/i).test(i)?x=i:/[a-z]/i.test(i)&&!r.test(s[j]||1)?i+x.toLowerCase():i).join``

Udało mi się to jeszcze bardziej napompować podczas gry w golfa O_o, ale to także naprawia błąd

s=>[x="",...s].map(             // Create a new array with x storing last vowel
                                // This also offsets indexes by one so rel to original str refers to next char
   (i,j)=>                      // Going through each char...
      (r=/[aeiou]/i).test(i)?   // If it's vowel, store it in x
          x=i:
      /[a-z]/i.test(i)          // If a letter (thats not a vowel excluded by above)
         &&!r.test(s[j]||1)?    // Test if next char is *not* vowel
         i+x.toLowerCase():i    // If it isn't, then add the most recent vowel after
    ).join``                    // Combine back to string
Downgoat
źródło
@RickHitchcock oh strzelał zupełnie zapomniał o zakończeniu char, naprawie jak najszybciej
Downgoat
1
@ RickHitchcock ok naprawiono
Downgoat
Ach, tak, dziękuję za golf @ETHproductions
Downgoat
3

JavaScript, 88 82 bajtów

Sporządzono z jednym wyrażeniem regularnym:

Wersja oryginalna (88 bajtów):

s=>s.replace(/(?<=([aeiou]).*?(?![aeiou])[a-z])(?=[^aeiou]|$)/gi,(_,c)=>c.toLowerCase())

Zaktualizowana wersja (82 bajtów) po zapoznaniu się z wyrażeniem regularnym Neila :

s=>s.replace(/(?<=([aeiou]).*?[^\W\d_aeiou])(?![aeiou])/gi,(_,c)=>c.toLowerCase())

var tests = {
  "AN EXAMPLE WITH A LOT UPPERCASE (plus some lowercase)":
    "ANa EXAMaPaLE WITiHi A LOTo UPuPEReCASE (pelusu some lowerecase)",
  "And here comes a **TEST** case with 10% symbols/numbers(#)!":
    "Anada here comese a **TESeTe** case witihi 10% siyimiboloso/numuberese(#)!",
  "This is an example string.":
     "Thisi isi ana examapale seterinigi.",
  "abcdefghijklmnopqrstuvwxyz":
    "abacadefegehijikiliminopoqorosotuvuwuxuyuzu",
  "A pnm bnn":
     "A panama banana",
  "Tell me if you need more test cases!":
     "Telele me ifi you neede more tesete casese!"
};

for ( test in tests )
{
  var result = (s=>s.replace(/(?<=([aeiou]).*?[^\W\d_aeiou])(?![aeiou])/gi,(_,c)=>c.toLowerCase()))(test);
  console.log( result === tests[test], result );
}

MT0
źródło
3

Japt -P , 28 bajtów

ó@\ctX ©\VtYÃËè\v ?P=D:D¬qPv

Wypróbuj online!

Rozpakowane i jak to działa

UóXY{\ctX &&\VtY} mD{Dè\v ?P=D:Dq qPv

UóXY{           }  Split the string between any two chars that don't satisfy...
     \ctX &&\VtY     The first char is a consonant and the second is a non-vowel
mD{                And map...
   Dè\v              If this item is a vowel...
       ?P=D            Assign it to P and return as-is
           :Dq qPv     Otherwise, split the item into chars and join with P lowercased
                       (P starts with "", so beginning consonants are not affected)

-P                 Join with ""

óFunkcja wygrywa nad wszelkiego rodzaju regexes.

Bubbler
źródło
Fajnie, pokonałeś mnie: D.
Magic Octopus Urn
Świetnie zrobione - sprawiłem sobie z tym poważny ból mózgu!
Kudłaty
2

JavaScript (Node.js) , 146 143 132 127 125 bajtów

(a,v="")=>[...a].map((b,i)=>(w=/[aeiou]/i).test(b)&&(v=b)?b:w.test(a[i+1]||b)||!b.match(/[a-z]/i)?b:b+v.toLowerCase()).join``

Wypróbuj online!

Luis Felipe De Jesus Munoz
źródło
2

Perl 6 ,  75 73 71  69 bajtów

{({S:i/.*(<[aeiou]>).*<-[\W\d_aeiou]><()><![aeiou]>/$0.lc()/}...*eq*).tail}

Spróbuj

{({S:i{.*(<[aeiou]>).*<-[\W\d_aeiou]><()><![aeiou]>}=$0.lc}...*eq*).tail}

Spróbuj

{({S:i{.*(<[aeiou]>).*<:L-[_aeiou]><()><![aeiou]>}=$0.lc}...*eq*).tail}

Spróbuj

{({S:i{.*(<[aeiou]>).*<:L-[_aeiou]><(<![aeiou]>}=$0.lc}...*eq*).tail}

Spróbuj

Rozszerzony:

{  # bare block lambda with implicit parameter $_

  (
    # generate a sequence

    {  # code block used to generate the values

      S               # substitute (not in-place)
      :i              # :ignorecase
      {

          .*              # start at end of string

          ( <[aeiou]> )   # store the previous vowel in $0

          .*

          <:L - [_aeiou]> # letter other than a vowel

          <(              # ignore everything before this

                          # this is where `$0.lc` gets inserted

          # )>            # ignore everything after this

          <![aeiou]>      # not a vowel (zero width lookahead)

      } = $0.lc       # replace with lowercase of the earlier vowel
    }

    ...    # keep generating until:

    * eq * # there are two equal strings (no changes)

  ).tail   # get the last value
}
Brad Gilbert b2gills
źródło
2

Python 3 , 125 bajtów

lambda s,v='[^aeiouAEIOU':sub(f'(?<={v}\W\d])(?={v}]|$)',lambda m:sub(f'{v}]','',s[:m.end()])[-1:].lower(),s)
from re import*

Wypróbuj online!

Python 3.6 pozwala nam (ab) używać f-stringów do ponownego wykorzystania naszego zestawu samogłosek (i dla czterech kolejnych zapisanych znaków, początek odwróconej klasy znaków regex) tanio ( fprefiks na każdym łańcuchu, a następnie {v}w razie potrzeby, zamiast '+v+'potrzebujesz konkatenacji lub [^aeiouAEIOUwstawiłbyś dosłownie.

Wyrażenie regularne, które nie pasuje do żadnych znaków, a tylko pozycja, pozwala uniknąć problemów z nie nakładającymi się dopasowaniami, których wymagają normalne wyrażenia regularne, i eliminuje potrzebę ponownego odniesienia dowolnej części dopasowania; używamy tylko obiektu dopasowania, aby uzyskać indeks plasterka, którego używamy do znalezienia poprzedniej samogłoski.

Częściowo bez golfa byłoby to coś w stylu:

import re

def get_last_vowel(string):
    '''
    Returns the lowercase version of the last vowel in a string if
    the string contains any vowels, otherwise, return the empty string
    '''
    try:
        *restvowels, lastvowel = re.sub(r'[^aeiouAEIOU]', '', string)
    except ValueError:
        lastvowel = ''  # No vowels in string
    return lastvowel.lower()

def rememebere_tehe_vowelese(string):
    '''Inserts the lowercased last vowel seen after any consonant not followed by a vowel'''
    return re.sub(r'(?<=[^aeiouAEIOU\W\d])(?=[^aeiouAEIOU]|$)',
                  lambda match: get_last_vowel(string[:match.end()]),
                  string)
ShadowRanger
źródło
2

TSQL, 500 bajtów

 CREATE TABLE i (i CHAR(999)); INSERT i VALUES ('The rain in Spain stays mainly in the plain')
 DECLARE @w CHAR(999)=(SELECT i FROM i),@r VARCHAR(999)='';WITH d(n,c,i,q)AS(SELECT n,SUBSTRING(@w,n,1),CHARINDEX(SUBSTRING(@w,n,1),'AEIOUaeiou'),CHARINDEX(SUBSTRING(@w,n,1),'BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz')FROM(SELECT DISTINCT number n FROM master..[spt_values]WHERE number BETWEEN 1 AND LEN(@w))D)SELECT @r=@r+f.c+LOWER(COALESCE(CASE WHEN f.q<>0 AND COALESCE(d2.i,0)=0 THEN SUBSTRING(@w,(SELECT MAX(n)FROM d WHERE i<>0 AND n<f.n),1)END,''))FROM d f LEFT JOIN d d2 ON f.n=d2.n-1 SELECT @r

Tabela isłuży do wprowadzania danych

Jan Drozen
źródło
2
Zakładanie, że dane wejściowe obecne w określonej zmiennej są generalnie niedozwolone . Czy można to zamiast tego dostosować do funkcji?
Laikoni
Zaktualizowano rozwiązanie Laikoni, aby pasowało do podanych reguł
Jan Drozen
2

SWI-Prolog, 593 bajty

a(S,D):-atom_chars(S,D).
g(_,[],_,-1).
g(E,[E|_],R,R).
g(E,[_|T],I,R):-N is I+1,g(E,T,N,R).
c(A,E):-g(E,A,0,R),R > -1.
v(X):-a('AEIOUaeiou',X).
c(X):-a('BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz',X).
d([_],_,R,R).
d([H|T],_,I,R):-v(V),c(V,H),!,d(T,H,I,[H|R]).
d([H,N|T],V,I,R):-c(C),c(C,H),v(W),c(W,N),!,d([N|T],V,I,[H|R]).
d([H,N|T],V,I,R):-c(C),c(C,H),v(W),\+c(W,N),string_lower(V,LV),!,d([N|T],V,I,[LV,H|R]).
d([H|T],V,I,R):-!,d(T,V,I,[H|R]).
r([],Z,Z).
r([H|T],Z,A):-r(T,Z,[H|A]).
r(S,D):-r(S,D,[]).
m(X,R):-a(X,O),r(O,P),r([''|P],Q),d(Q,'',I,[]),r(I,J,[]),atomic_list_concat(J,R).

Używany tylko z wbudowanymi predykatami (bez wyrażeń regularnych i biblioteki do manipulowania listami).

Stosowanie:

?- m('A pnm bnn').
'A panama banana'
true .
Jan Drozen
źródło
2

Haskell , 142 130 bajtów

""&
import Data.Char
v=(`elem`"aeiouAEIOU")
s&(x:y:z)|v y=x:s&(y:z)
s&(x:y)|v x=x:[toLower x]&y|isAlpha x=x:s++s&y|1>0=x:s&y
_&x=x

Wypróbuj online!

Inicjał ""&jest częściowym zastosowaniem (&)funkcji zdefiniowanej później i jest tak dziwnie umieszczony, aby TIO policzył bajty ""&, ale nie zlicza bajtów, które w pełnym programie byłyby potrzebne, aby przypisać je do dowolnej nazwanej wartości.


Mniej golfa:

import Data.Char (isAlpha, toLower)

vowel :: Char -> Bool
vowel = (`elem`"aeiouAEIOU")

replace :: String -> String
replace = go "" -- start by carrying no extra vowel
  where go _ "" = ""
        -- special case for "anything followed by vowel" so later cases can ignore next character
        go s (x:y:more) | vowel y = x : go s (y:more)
        go s (x:xs) | vowel x = x : go [toLower x] xs -- update the vowel we're carrying
                    | isAlpha x = x : s ++ go s xs -- non-vowel letter not followed by a vowel
                    | otherwise = x : go s xs -- some non-letter junk, just include it and carry on

Naprawdę powinien istnieć sposób, aby zrobić to bardziej zwięźle z fałdem zamiast rekurencji, ale nie mogłem tego rozgryźć.

amalloy
źródło
Oto bardzo hackerski sposób definiowania nagłówka, który fnie pojawia się w treści: Wypróbuj online!
Laikoni
Istnieją dwie niepotrzebne spacje v = (i można zdefiniować gjako operator infix .
Laikoni
Umieszczenie skrzynki podstawowej g _""=""w ostatniej pozycji oszczędza bajt: g _ x=x(dwa bajty, jeśli przejdziesz na infix, jak sugeruje Laikoni).
nimi
Zgodnie z naszymi konwencjami musisz dodać nawias, ""&aby funkcja działała.
Laikoni
1

05AB1E , 34 bajty

vyžMylåil©1V}žPylåžM¹N>èå_Y&&i®«}J

Wypróbuj online!


Cofam to, że mogę ogolić 3 bajty z tej potworności ... Myślę, że mógłbym ogolić wartość logiczną, ale MUSZĄ być 3 przypadki. 1 dla samogłosek. 1 dla spółgłosek. 1 w przypadku istnienia cyfry / symbolu.


v                                 # For each...
 y                                # Push current element.
  žM                              # Push lower-case vowels (aeiou).
    ylå                           # Lower-case current element is vowel?
       i©1V}                      # If so, put it in register, set Y to 1.
            žP                    # Push lower-case consonants (b...z)
              ylå                 # Is current char a consonant?
                 žM¹N>èå_         # Push vowels again, is input[N+1] NOT a vowel? 
                         Y        # Did we ever set Y as 1?
                          &&      # All 3 previous conditions true?
                            i®«}  # Concat the current vowel to the current char.
                                J # Join the whole stack.
                                  # '}' isn't needed here, b/c it's implied.
                                  # Implicit return.
Urna Magicznej Ośmiornicy
źródło
0

PowerShell, 104 bajty

na podstawie wyrażenia regularnego Neila .

[regex]::Replace($args,'(?i)(?<=([aeiou]).*?[^\W\d_aeiou])(?![aeiou])',{"$($args.Groups[1])".ToLower()})

zapisz to jako get-rememebere.ps1. Skrypt do testowania:

$test = @"
AN EXAMPLE WITH A LOT UPPERCASE (plus some lowercase)
And here comes a **TEST** case with 10% symbols/numbers(#)!
This is an example string.
abcdefghijklmnopqrstuvwxyz
A pnm bnn
Tell me if you need more test cases!
"@

$expected = @"
ANa EXAMaPaLE WITiHi A LOTo UPuPEReCASE (pelusu some lowerecase)
Anada here comese a **TESeTe** case witihi 10% siyimiboloso/numuberese(#)!
Thisi isi ana examapale seterinigi.
abacadefegehijikiliminopoqorosotuvuwuxuyuzu
A panama banana
Telele me ifi you neede more tesete casese!
"@

$result = .\get-rememebere.ps1 $test
$result -eq $expected
$result
mazzy
źródło
1
Czy to nie tylko fragment? Mam na myśli, że PowerShell ma dane wejściowe, więc nie możesz założyć, że dane wejściowe są w $t. Odpowiedni meta post: codegolf.meta.stackexchange.com/a/8731/78123
wastl
0

Czerwony , 276 bajtów

func[s][v: charset t:"AEIOUaeiou"c: charset 
u:"BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz"b:
parse s[collect[any keep[thru c opt v]keep thru end]]p:""foreach
c b[either find t e: last c: to-string c[p: e][parse c[any[copy p v
| skip]]if find u e[append c lowercase p]]prin c]]

Wypróbuj online!

Czytelny:

f: func [ s ] [
   v: charset t: "AEIOUaeiou"
   c: charset u: "BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz"
   b: parse s [
       collect [ any keep [ thru c opt v ]
       keep thru end ]
   ]
   p: "" 
   foreach c b [
       e: last c: to-string c
       either find t e [ p: e ][
           parse c [ any [ copy p v | skip ] ]
           if find u e [ append c lowercase p ]
       ]
       prin c
   ]
]
Galen Iwanow
źródło
0

Yabasic , 180 bajtów

Pełny program, który pobiera dane ze STDIN i wysyła do STDOUT

Line Input""s$
x$="AEIOUaeiou"
For i=1To Len(s$)
c$=Mid$(s$,i,1)
?c$;
If InStr(x$,c$)Then
v$=c$
Else
a=Asc(Upper$(c$))
If a>64And a<91And!InStr(x$,Mid$(s$,i+1,1))Then?v$;Fi
Fi
Next

Wypróbuj online!

Taylor Scott
źródło