覚えておいてください!


25

入力

印刷可能なASCII文字の文字列、たとえば:

This is an example string.

出力

BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz母音(AEIOUaeiou)が後に続かない子音()ごとに、その前の最後の母音を小文字で追加します。
最初の母音の前の子音はそのまま残されます

Thisi isi ana examapale seterinigi.

テストケース

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!

得点

これはであるため、各言語で最小のバイト数を持つ答えが勝ちます(答えは受け入れられません)。


それで、挿入された母音は常に小文字である必要がありますが、テキストは大文字と小文字の両方かもしれませんか?
エリックアウトゴルファー

出力をリスト/配列の形式にすることはできますか?
ネイサンディマー

1は、隣接する文字の場合チェックしていた場合、我々は小文字する必要がどこ@EriktheOutgolferはい、私は大文字たくなかったが、それは挑戦をovercomplicatedているだろう
wastlを

11
健康な子供を食べてみてくださいA pnm bnn
スチューイーグリフィン

4
他の誰かが「イタリア人」がタイトルのどこかに行く必要があると思いますか?
アルテリウス

回答:



8

JavaScript(ES6)、108 105バイト

(@Shaggyのおかげで3バイト保存されました。)

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

母音または後続の母音がない子音を検索します。

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

(子音を明示的に検索する必要はありません/[aeiou]|...。母音はに基づいて除外されるためです。)

母音はに保存されv、次の母音のない子音がv挿入されています。

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

r[1]存在する場合は、子音と非母音で照合しました。)

何も変更されていない場合は、入力を返します。それ以外の場合、置換された文字列を再帰します。


1
これはさらに良いです。私は本当に正規表現を見る必要があります
ルイスフェリペデジェススムニョス

地図上での置換+参加を使用する+1スマートアイデア
Downgoat

再帰なしであなたの(ほぼ)作業バージョンをベースに:s=>s.replace(/[aeiou][^a-z]*([a-z](?![aeiou]))+/gi,s=>s.replace(/(?!^)./g,a=>a+s[0].toLowerCase()))私も非文字の配列との問題を持っているように見えることはできません
Downgoat

再帰は確かにここで物事を単純化します。
リックヒッチコック

(s+=' ')数バイト節約できます。
シャギー


4

標準ML225 223バイト

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;

オンラインでお試しください!

少ないゴルフ:

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;

オンラインでお試しください!


わあ、MLゴルフは本当に面白いですね!変数名のit使用が大好き$です。
リン

@Lynn私が書いた先端を識別子がに関するいくつかの時間前に名前変更と書き込み1に、計画についてitも、まだそう周りをもらっていません。
ライコニ


4

Perl 5の、68の 67 59バイト

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

これがの有用性の素晴らしい例です\K。DomHastingsが指摘する前にこの機能について知らなかったとは信じられません。

を使用しただけでは適切な動作が得られなかったs///gため、実際のループが必要なようです。(後読みアサーションの正しい使用が明示的になくても機能する可能性はありますwhileが、私はそれを見つけていません。)


素敵なアプローチ!より良いものを思い付くことができませんでしたが、なんとか6バイトを取得することができました:オンラインで試してみてください!
ドムヘイスティングス

1
@DomHastings:[aeiou])変数を考慮してさらに短く(58バイトまで):オンラインで試してみてください!
ShadowRanger

3

JavaScript ES6、115バイト

@ETHProductionsのおかげで8バイト節約

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``

O_oでゴルフをする過程でこれをさらに膨らませることができましたが、バグも修正されました。

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

@RickHitchcockああ撮影は完全に、文字を終了できるだけ早く固定し忘れてしまった
Downgoat

1
@RickHitchcock OK固定
Downgoat

ああ、はいゴルフ@ETHproductionsに感謝
Downgoat

3

JavaScript、88 82バイト

単一の正規表現で完了:

オリジナルバージョン(88バイト):

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

ニールの正規表現を見た後のバージョン(82バイト)の更新:

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 );
}


3

ジャプト -P、28バイト

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

オンラインでお試しください!

開梱と仕組み

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 ""

このó関数は、あらゆる種類の正規表現に勝ちます。


ナイスな、yaが私を倒した:D。
魔法のタコUr

うまくやった-私はこれで自分自身にひどい頭痛を与えた!
シャギー


2

Perl 6の 75の73 71  69バイト

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

それを試してみてください

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

それを試してみてください

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

それを試してみてください

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

それを試してみてください

拡張:

{  # 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
}

2

Python 3、125バイト

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

オンラインでお試しください!

Python 3.6では、f-stringを使用して母音のセット(および保存された4文字以上、逆正規表現文字クラスの先頭)を安価に(ab)使用できます(f各文字列のプレフィックス{v}、必要に応じて、'+v+'連結で必要になるか、[^aeiouAEIOU文字通り挿入します。

文字だけでなく位置だけに一致する正規表現は、通常の正規表現が必要とする非重複一致の問題を回避し、一致部分を後方参照する必要をなくします。一致オブジェクトを使用するのは、前の母音を見つけるために使用するスライスインデックスを取得することだけです。

部分的にゴルフを解体した場合、次のようになります。

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)

2

TSQL、500バイト

 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

テーブルi入力に使用されます


2
入力が特定の変数に存在すると仮定することは一般に許可されていません。これを代わりに機能に適応させることはできますか?
ライコニ

@Laikoniソリューションが特定のルールに一致するように更新されました
Jan

2

SWI-Prolog、593バイト

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).

組み込みの述部のみを使用しました(正規表現またはリスト操作ライブラリなし)。

使用法:

?- m('A pnm bnn').
'A panama banana'
true .

2

Haskell142130バイト

""&
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

オンラインでお試しください!

イニシャル""&は、(&)後で定義される関数の部分的なアプリケーションであり、TIOがのバイトをカウントするように奇妙に配置され""&ますが、完全なプログラムではそれを任意の名前の値に割り当てるために必要なバイトをカウントしません。


少ないゴルフ:

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

再帰の代わりにフォールドを使用してこれをより簡潔に行う方法が実際にあるはずですが、私はそれを理解できませんでした。


f本文に表示されないようにヘッダーを定義する非常にハックな方法を次に示します。オンラインで試してみてください!
ライコニ

には2つの不要なスペースがv = (ありg中置演算子として定義できます。
ライコニ

ベースケースg _""=""を最後の位置に置くと、バイトが節約されますg _ x=x(Laikoniが示唆するように中置に切り替えると2バイト)。
nimi

慣例に従って、括弧を追加""&して関数にする必要があります。
ライコニ

1

05AB1E、34バイト

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

オンラインでお試しください!


私はそれを取り戻し、この怪物から3バイトしか剃ることができません...私はブール値を減らすことができると思いますが、3つのケースがなければなりません。母音の場合は1。子音の場合は1。数字/記号が存在する場合は1。


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.

0

Powershell、104バイト

ニールの正規表現に基づいています

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

として保存しますget-rememebere.ps1。テスト用のスクリプト:

$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

1
これは単なるスニペットではありませんか?つまり、powershellには入力があるので、入力がであると仮定することはできません$t。関連するメタ投稿:codegolf.meta.stackexchange.com/a/8731/78123
wastl

0

、276バイト

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]]

オンラインでお試しください!

読みやすい:

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
   ]
]

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.