А чи Ан?


21

В англійській мові є весела і проста різниця між anі a: ви використовуєте, anколи передує слово, що починається з голосного звуку, і aколи слово починається з приголосного звуку.

Для простоти в цьому виклику anпередує слово, яке починається з голосної ( aeiou), і aпередує слову, яке починається з приголосного.

Вхідні дані

Рядок, що містить лише символи для друку ASCII, із [?]місцями, де потрібно вибрати вставити anабо a. [?]завжди з’явиться перед словом. Можна припустити, що речення буде граматично правильним та відформатованим як звичайне.

Вихідні дані

Рядок введення на [?]замінено відповідним словом ( anабо a). Вам доведеться турбуватися про капіталізацію!

Коли капіталізувати

Використовуйте великі літери, якщо перед ним немає жодних символів (є першим у введенні) або якщо йому передує один з .?!наступних пробілів.

Приклади

Input: Hello, this is [?] world!
Output: Hello, this is a world!

Input: How about we build [?] big building. It will have [?] orange banana hanging out of [?] window.
Output: How about we build a big building. It will have an orange banana hanging out of a window.

Input: [?] giant en le sky.
Output: A giant en le sky.

Input: [?] yarn ball? [?] big one!
Output: A yarn ball? A big one!

Input: [?] hour ago I met [?] European.
Output: A hour ago I met an European.

Input: Hey sir [Richard], how 'bout [?] cat?
Output: Hey sir [Richard], how 'bout a cat?

Це , тому найкоротший код у байтах виграє!


Добре, дякую. Чи можемо ми припустити, що жоден ввід не матиме зайвих пробілів між [?]словом і словом?
DJMcMayhem

8
Чи потрібно вводити великі літери в середині вводу, коли це йде на початку речення? ("Це тест [?]. [?] Тест.") Якщо так, то з яким пунктуацією може закінчуватися речення? А як щодо речень у лапках чи дужках? Або абревіатури, які закінчуються через певний період ("Напр. [?] Введення так")? Правила капіталізації мають безліч дивних особливих випадків, тому будь ласка, будьте чітко розкриті щодо того, що роблять наші програми чи не потрібно їх обробляти.
DLosc

1
Не могли б ви уточнити, коли потрібно використовувати великі капітали? Перший персонаж?
DJMcMayhem

31
Ви повинні додати тестовий випадок [?] hour ago I met [?] European.лише для того, щоб усі знущалися.
Мартін Ендер

1
Тепер ми повинні мати[?] hour ago I met [?] horse.
стакан

Відповіді:


6

V , 41 байт

ÍãÛ?Ý ¨[aeiou]©/an
ÍÛ?Ý/a
Í^aü[.!?] a/A

Спробуйте в Інтернеті! , який зручно також можна використовувати для перевірки всіх тестових випадків без додаткового кількості байтів.

Для цього використовується перевага V "стиснення Regex" V. Тут використовується безліч недрукованих символів, тому ось шестинадцять:

0000000: cde3 db3f dd85 20a8 5b61 6569 6f75 5da9  ...?.. .[aeiou].
0000010: 2f61 6e0a cddb 3fdd 2f61 0acd 5e61 fc5b  /an...?./a..^a.[
0000020: 2e21 3f5d 2093 612f 41                   .!?] .a/A

На жаль, OP сказав : «Ви дійсно повинні турбуватися про капіталізацію!» (наголос мій).
El'endia Starman

1
@ El'endiaStarman О, я це неправильно прочитав. Я можу це виправити, але я не маю поняття, чим скористатися, оскільки ОП не вказав.
DJMcMayhem

@ El'endiaStarman Виправлено зараз.
DJMcMayhem

7

Perl, 48 байт

Збережено 1 байт завдяки тону Євангелія .

#!perl -p
s;\[\?];A.n x$'=~/^ [aeiou]/i^$"x/[^.?!] \G/;eg

Підрахувавши шебанг як один, вхід береться з stdin.

Пояснення

#!perl -p               # for each line of input, set $_, auto-print result

s;                      # begin regex substitution, with delimiter ;
\[\?]                   # match [?] literally, and replace with:
;
A.n x$'=~/^ [aeiou]/i   # 'A', concatenate with 'n' if post-match ($')
                        #   matches space followed by a vowel
^$"x/[^.?!] \G/         # if the match is preceded by /[^.?!] /, xor with a space
                        #   this will change An -> an

;eg                     # regex options eval, global

Використання зразка

$ echo Hello, this is [?] world! | perl a-an.pl
Hello, this is a world!

$ echo How about we build [?] big building. It will have [?] orange banana hanging out of [?] window. | perl a-an.pl
How about we build a big building. It will have an orange banana hanging out of a window.

$ echo [?] giant en le sky. [?] yarn ball? | perl a-an.pl
A giant en le sky. A yarn ball?

$ echo [?] hour ago I met [?] European. | perl a-an.pl
A hour ago I met an European.

2
Чи можете ви пояснити це, будь ласка?
sudee

1
Підтримка капіталізації після /[.?!]/пробілу відсутня
Тон Євангелія

1
@TonHospel 10 годин тому проблема не згадувала про це.
примо

2
Гаразд, змінювати специфікацію на льоту так нечесно. PS: Я люблю використовувати, \Gщоб повернутися назад. PPS, трохи коротше:s;\[\?];A.n x$'=~/^ [aeiou]/^$"x/[^.?!] \G/;eg
Ton Hospel

1
@sudee оновлено, щоб включити пояснення.
примо

7

Рубі, 78 72 байти

->s{s.gsub(/(^|\. )?\K\[\?\]( [aeiou])?/i){"anAn"[$1?2:0,$2?2:1]+"#$2"}}
  • Збережено 6 байт завдяки @Jordan

Безумовно

def f(s)
    s.gsub(/(^|\. )?\[\?\]( [aeiou])?/i) do |m|
        capitalize = $1
        vowel = $2
        replacement = if vowel then
            capitalize ? "An" : "an"
        else
            capitalize ? "A" : "a"
        end
        m.sub('[?]', replacement)
    end
end

2
"anAn"[...]справді розумний. 👍🏻 Ви можете зберегти кілька байт, пропустивши внутрішнє sub:s.gsub(/(^|\. )?\K\[\?\] ([aeiou])?/i){"anAn"[$1?2:0,$2?2:1]+" #$2"}
Йорданія,

6

PHP, 207 байт

foreach(explode("[?]",$s)as$i=>$b){$r=Aa[$k=0|!strstr(".!?",''==($c=trim($a))?".":$c[strlen($c)-1])].n[!preg_match("#^['\"´`\s]*([aeiou]|$)#i",$d=trim($b))];echo$i?$r.$b:$b;$a=$i?''==$d?a:$b:(''==$d?".":a);}

Мені подобаються рішення, які час від часу є повнішими ...
але мушу визнати, що це трохи непосильне, хоча воно ще зовсім не закінчено.

Збережіть у файл, запустіть php <filename>із введенням STDIN.

тестові справи

How about we build [?] big building ... with [?] orange banana hanging out of [?] window.
=>  How about we build a big building ... with an orange banana hanging out of a window.

Hello, this is [?] world!               =>  Hello, this is a world!
Should I use [?] '[?]' or [?] '[?]'?    =>  Should I use an 'an' or an 'a'?
[?] elephant in [?] swimsuit.           =>  An elephant in a swimsuit.

How I met your moth[?].                 =>  How I met your motha.
b[?][?][?] short[?]ge!                  =>  banana shortage!

зламатися

foreach(explode("[?]",$s)as$i=>$b)
{
    $r=
        // lookbehind: uppercase if the end of a sentence precedes
        Aa[$k=0|!strstr(".!?",''==($c=trim($a))?".":$c[strlen($c)-1])]
        .
        // lookahead: append "n" if a vowel follows (consider quote characters blank)
        n[!preg_match("#^['\"´`\s]*([aeiou]|$)#i",$d=trim($b))]
    ;
    // output replacement and this part
    echo$i?$r.$b:$b;
    // prepare previous part for next iteration
    $a=$i               // this part was NOT the first:
        ?   ''==$d
            ? a             // if empty -> a word ($r from the previous iteration)
            : $b            // default: $b
        :  (''==$d      // this WAS the first part:
            ? "."           // if empty: end of a sentence (= uppercase next $r)
            : a             // else not
        )
    ;
    // golfed down to `$a=!$i^''==$d?a:($i?$b:".");`
}

3
Підвищення за "дефіцит бананів"! LOL
MonkeyZeus

@MonkeyZeus: Спробуйте[?][?][?]s [?]lert!
Тіт

Все, що я можу собі уявити, - це сердечно розбитий Donkey Kong, який хвилюється через нестачу :(
MonkeyZeus

5

Мінколанг 0,15 , 75 байт

od4&r$O."]?["30$Z3&00w4X"Aa"I2-"Aa ."40$Z,*2&$rxr$O" aeiou"od0Z1=3&"n"r5X$r

Спробуйте тут!

Пояснення

od                                                                    Take character from input and duplicate (0 if input is empty)
  4&                                                                  Pop top of stack; jump 4 spaces if not 0
    r$O.                                                              Reverse stack, output whole stack as characters, and stop.

    "]?["                                                             Push "[?]" on the stack
         30$Z                                                         Pop the top 3 items and count its occurrences in the stack
              3&                                                      Pop top of stack; jump 3 spaces if not 0
                00w                                                   Wormhole to (0,0) in the code box

                3X                                                    Dump the top 3 items of stack
                  "Aa"                                                Push "aA"
                      I2-                                             Push the length of stack minus 2
                         "Aa ."40$Z,                                  Push ". aA" and count its occurrences, negating the result
                                    *                                 Multiply the top two items of the stack
                                     2&$r                             Pop top of stack and swap the top two items if 0
                                         x                            Dump top of stack
                                          r                           Reverse stack
                                           $O                         Output whole stack as characters
                                             " aeiou"                 Push a space and the vowels
                                                     od               Take a character from input and duplicate
                                                       0Z             Pop top of stack and count its occurrences in the stack (either 1 or 2)
                                                         1=           1 if equal to 1, 0 otherwise
                                                           3&         Pop top of stack; jump 3 spaces if not 0
                                                             "n"      Push "n" if top of stack is 0

                                                             r        Reverse stack
                                                              5X      Dump top five items of stack
                                                                $r    Swap top two items of stack

Зауважте, що оскільки Міколанг є тороїдальним, коли лічильник програми відсувається від правого краю, він знову з’являється зліва. Звичайно, гольфуючий, але оскільки мені довелося додати 21 байт через специфікацію, я, можливо, не спробую.


6
Чи я єдиний, хто хоче піти грати в ексклюзивний велосипед, прочитавши це пояснення?
Чарівна восьминога урна

3

JavaScript (ES6), 90 86 87 85

Ще раз відредагуйте, як змінилася специфікація з великої літери (тепер більш розумна)

Змініть ще раз 1 байт збереження thx @Huntro

Відредагуйте ще 2 байти, щоб керувати цитатами тощо, як вказував IsmaelMiguel (навіть якщо я не знаю, чи це запитується оп). Зауважте, що раніше я нарахував 86 байт, але їх було 85

Намагайтесь дотримуватися правила капіталізації, зазначеного в коментарі, якщо воно неповне (принаймні)

x=>x.replace(/([^!?.] )?\[\?](\W*.)/g,(a,b,c)=>(b?b+'a':'A')+(/[aeiou]/i.test(c)?'n'+c:c))

Тест

f=x=>x.replace(/([^!?.] )?\[\?](\W*.)/g,(a,b,c)=>(b?b+'a':'A')+(/[aeiou]/i.test(c)?'n'+c:c))

function go() {
  var i=I.value, o=f(i)
  O.innerHTML = '<i>'+i+'</i>\n<b>'+o+'</b>\n\n'+O.innerHTML 
}

go()
#I { width:80% }
<input value='How about we build [?] big building. It will have [?] orange banana hanging out of [?] window.' id=I><button onclick='go()'>GO</button><pre id=O></pre>


Не варто [?][?]давати Ana? І не повинні [?][?] a.виробляти Ana a.?
Ісмаїл Мігель

@IsmaelMiguel Я не розумію, що саме ти маєш на увазі, але все одно[?] will always appear before a word. You can assume that the sentence will be grammatically correct and formatted like normal.
edc65

Зрозумів, але ваш код дає дивні результати для [?] "[?]".( An "A", котирування не мають значення) і для [?] "A".(це чудово працює [?] A.).
Ісмаель Мігель

@IsmaelMiguel невірний [?] "[?]"ввід. [?] will always appear before a word і "[?]" - це не слово.
edc65

2
Уникнути секунди ]не потрібно. /(\w )?\[\?](\W*.)/g
Huntro

2

Пакетна, 136 байт

@set/ps=
@for %%v in (a e i o u)do @call set s=%%s:[?] %%v=an %%v%%
@set s=%s:[?]=a%
@if %s:~0,1%==a set s=A%s:~1%
@echo %s:. a=. A%

Бере рядок введення на STDIN.


2

PHP, 100 92 байт

<?=preg_filter(["/\[\?]\K(?= [aeiou])/i","/([.?!] |^)\K\[\?]/","/\[\?]/"],[n,A,a],$argv[1]);

Можна було надалі гольфувати регулярні вирази.

Повідомляє про невизначену константу, але все ще працює.

Редагувати: 8 байтів збережено завдяки приміту


Слід також мати можливість зменшити масив заміни [n,A,a], використовуючи твердження ( \Kі (?= )) для обстеження .
примо

2

Python 3.5.1, 153 147 124 байт

*s,=input().replace('[?]','*');print(*[('a','A')[i<1or s[i-2]in'.?!']+'n'*(s[i+2]in 'aeiouAEIOU')if c=='*'else c for i,c in enumerate(s)],sep='')

Вхід:

[?] apple [?] day keeps the doctor away. [?] lie.

Вихід:

An apple a day keeps the doctor away. A lie.

Версія 123 байтів - це не обробляє правило з великої літери.

s=list(input().replace('[?]','*'));print(*['a'+'n'*(s[i+2]in 'aeiouAEIOU')if c=='*'else c for i,c in enumerate(s)],sep='')

Ідей це!


1
Ласкаво просимо до Codegolf. Ви можете користуватися ним ;і гольфу.
ABcDexter

1
m.start() forповинно бути m.start()for, s[i+2] in 'aeiouAEIOU'повинно бути s[i+2]in'aeiouAEIOU'. Легке -3-байтове гоління за рахунок білого простору.
Ерік Аутгольфер

1
('an','a')[s[i+2]in'aeiouAEIOU']інвертовано, ви можете використати це, 'a'+'n'*(s[i+2]in'aeiouAEIOU')щоб виправити це і зберегти 2 байти. Тут ви можете знайти безліч порад щодо гольфу .
Стер

1
Ця громада така мила, бачачи, скільки людей готові допомогти новачкам та надати поради щодо гольфу!
yo

1
Нічого собі enumerate()класно. Дякую @chepner.
Гурупад Мамадапур

2

Java, 180 178 байт

У моєму першому дописі тут я використовував частину посади Кевіна Круїссена, але, з іншим підходом, він допоміг мені трохи скоротити, завдяки йому!

String c(String s){String x[]=s.split("\\[\\?]",2),r=x[0];return x.length>1?r+(r.matches("(.+[.!?] )|(^)$")?"A":"a")+("aeiouAEIOU".contains(""+x[1].charAt(1))?"n":"")+c(x[1]):r;}

Ось це невольф:

static String c(String s) {
        String x[] = s.split("\\[\\?\\]", 2), r = x[0];
        return x.length > 1 ? r + (r.matches("(.+[.!?] )|(^)$") ? "A" : "a")
                + ("aeiouAEIOU".contains("" + x[1].charAt(1)) ? "n" : "") + c(x[1]) : r;
    }

І результат

Просте пояснення, я використовую рекурсивний підхід, щоб знайти кожного [?].

Я не міг знайти спосіб використовувати сірники з нечутливим випадком (не впевнений, що це можливо).

178 байт: Дякую Мартіну Ендеру!


1
Ласкаво просимо до PPCG! Я не думаю, що вам не потрібно уникати ]свого регексу.
Мартін Ендер

Ви маєте рацію, тільки відкриття вистачає, дякую
AxelH

2

05AB1E , 38 36 35 байт

2FžNžM‚NèSðì…[?]©ìDu«D®'a'nN׫::}.ª

Спробуйте в Інтернеті або перевірте всі тестові випадки .

Пояснення:

2F            # Loop 2 times:
  žN          #  Push consonants "bcdfghjklmnpqrstvwxyz"
  žM          #  Push vowels "aeiou"
             #  Pair them together into a list
     Nè       #  And use the loop-index to index into this pair
  S           #  Convert this string to a list of characters
   ðì         #  Prepend a space in front of each character
     …[?]     #  Push string "[?]
         ©    #  Store it in variable `®` (without popping)
          ì   #  And prepend it in front of each string in the list as well
  }D          #  Then duplicate the list
    u         #  Uppercase the characters in the copy
     «        #  And merge the two lists together
              #   i.e. for the vowel-iteration we'd have ["[?] a","[?] e","[?] i","[?] o",
              #    "[?] u","[?] A","[?] E","[?] I","[?] O","[?] U"]
   D          #  Duplicate it
    ®         #  Push "[?]" from variable `®`
     'a      '#  Push "a"
       'n    '#  Push "n"
         N×   #  Repeated the 0-based index amount of times (so either "" or "n")
           «  #  And append it to the "a"
    :         #  Replace all "[?]" with "an"/"a" in the duplicated list
     :        #  And then replace all values of the lists in the (implicit) input-string
 }.ª          #  After the loop: sentence-capitalize everything (which fortunately retains
              #  capitalized words in the middle of sentences, like the "European" testcase)
              # (and after the loop the result is output implicitly)

1
У ньому трохи помилок. Він пише з великої літери після слова "an". Наприклад, "[?] Апельсин" стає "апельсином". Здається, працює, якщо ви додасте ]після::
Доріан

@Dorian Woops .. Я видалив це }пізніше, тому що думав, що це збереже байт, але ти справді маєш рацію, що не вдається для [?] vowelвипадків .. Дякую за те, що повідомили мені!
Кевін Крейссен

1

C #, 204 235 байт

string n(string b){for(int i=0;i<b.Length;i++){if(b[i]=='['){var r="a";r=i==0||b[i-2]=='.'?"A":r;r=System.Text.RegularExpressions.Regex.IsMatch(b[i+4].ToString(),@"[aeiouAEIOU]")?r+"n":r;b=b.Insert(i+3,r);}}return b.Replace("[?]","");}

Повна програма без вольфів:

using System;

class a
{
    static void Main()
    {
        string s = Console.ReadLine();
        a c = new a();
        Console.WriteLine(c.n(s));
    }

    string n(string b)
    {
        for (int i = 0; i < b.Length; i++)
        {
            if (b[i] == '[')
            {
                var r = "a";
                r = i == 0 || b[i - 2] == '.' ? "A" : r;
                r = System.Text.RegularExpressions.Regex.IsMatch(b[i + 4].ToString(), @"[aeiouAEIOU]") ? r + "n" : r;
                b = b.Insert(i + 3, r);
            }
        }
        return b.Replace("[?]", "");
    }
}

Я впевнений, що це можна вдосконалити, особливо частину Regex, але зараз нічого не можу придумати.


це працює без імпорту?
кіт

Ну, забув включити імпорт регулярного виразу.
Йодл

1
Код для гольфу повинен працювати як є в будь-якому форматі - якщо він не запускається без імпортування регулярних виразів, то імпорт регулярного вибору повинен також входити і в код гольфу
кіт

Добре, дякую. Ще прасую, як саме відповісти. Підрахунок та відповідь включають System.Text.RegularExpressions зараз.
Йодл

Це зараз добре виглядає. :) Ви також можете перевірити Code Golf Meta та тег faq там.
кіт

1

Java 7, 239 214 213 байт

String c(String s){String x[]=s.split("\\[\\?\\]"),r="";int i=0,l=x.length-1;for(;i<l;r+=x[i]+(x[i].length()<1|x[i].matches(".+[.!?] $")?65:'a')+("aeiouAEIOU".contains(x[++i].charAt(1)+"")?"n":""));return r+x[l];}

Невикористані та тестові справи

Спробуйте тут.

class M{
  static String c(String s){
    String x[] = s.split("\\[\\?\\]"),
           r = "";
    int i = 0,
        l = x.length - 1;
    for (; i < l; r += x[i]
                     + (x[i].length() < 1 | x[i].matches(".+[.!?] $") 
                        ? 65
                        : 'a')
                     + ("aeiouAEIOU".contains(x[++i].charAt(1)+"")
                        ? "n"
                        : ""));
    return r + x[l];
  }

  public static void main(String[] a){
    System.out.println(c("Hello, this is [?] world!"));
    System.out.println(c("How about we build [?] big building. It will have [?] orange banana hanging out of [?] window."));
    System.out.println(c("[?] giant en le sky."));
    System.out.println(c("[?] yarn ball? [?] big one!"));
    System.out.println(c("[?] hour ago I met [?] European. "));
    System.out.println(c("Hey sir [Richard], how 'bout [?] cat?"));
    System.out.println(c("[?] dog is barking. [?] cat is scared!"));
  }
}

Вихід:

Hello, this is a world!
How about we build a big building. It will have an orange banana hanging out of a window.
A giant en le sky.
A yarn ball? A big one!
A hour ago I met an European. 
Hey sir [Richard], how 'bout a cat?
A dog is barking. A cat is scared!

Я спробував використовувати рекурсивне рішення, я закінчую на 2 байти більше, ніж ви :( потрібно вдосконалити, можливо .. але, оскільки я використовую ваш регекс, я не люблю його публікувати.
AxelH

@AxelH Ви можете, можливо, розмістити його на ideone та посилання тут? Разом ми можемо помітити щось для гольфу. ;)
Кевін Круїссен

Ось це ideone.com/z7hlVi , я знайшов кращий підхід, ніж isEmptyвикористання регулярного виразу ^$. Я вважаю, що закінчую 202;)
AxelH

@AxelH Ах приємно. Хм, я рахую 195 байт замість 202? До речі, ви можете пограти в гольф до 180, зробивши пряме повернення з потрійним, якщо ще: String c(String s){String x[]=s.split("\\[\\?\\]",2),r=x[0];return x.length>1?r+(r.matches("(.+[.!?] )|(^)$")?"A":"a")+("aeiouAEIOU".contains(""+x[1].charAt(1))?"n":"")+c(x[1]):r;}Так, безумовно, коротше моєї відповіді на цикл. :)
Кевін Кройсейсен

О так, мені вдається поставити блок if в один рядок в кінці, забувши його замінити. Спасибі;
AxelH

1

Ракетка 451 байт (без регулярного вираження)

Це, очевидно, довга відповідь, але він замінює також і величину з великою літерою:

(define(lc sl item)(ormap(lambda(x)(equal? item x))sl))
(define(lr l i)(list-ref l i))(define(f str)(define sl(string-split str))
(for((i(length sl))#:when(equal?(lr sl i)"[?]"))(define o(if(lc(string->list"aeiouAEIOU")
(string-ref(lr sl(add1 i))0))#t #f))(define p(if(or(= i 0)(lc(string->list".!?")
(let((pr(lr sl(sub1 i))))(string-ref pr(sub1(string-length pr))))))#t #f))
(set! sl(list-set sl i(if o(if p"An""an")(if p"A""a")))))(string-join sl))

Тестування:

(f "[?] giant en le [?] sky.")
(f "[?] yarn ball?")
(f "[?] hour ago I met [?] European. ")
(f "How about we build [?] big building. It will have [?] orange banana hanging out of [?] window.")
(f "Hello, this is [?] world!")

Вихід:

"A giant en le a sky."
"A yarn ball?"
"A hour ago I met an European."
"How about we build a big building. It will have an orange banana hanging out of a window."
"Hello, this is a world!"

Детальна версія:

(define(contains sl item)
  (ormap(lambda(x)(equal? item x))sl))

(define(lr l i)
  (list-ref l i))

(define(f str)
  (define sl(string-split str))
  (for((i(length sl))#:when(equal?(lr sl i)"[?]"))
    (define an   ; a or an
      (if(contains(string->list "aeiouAEIOU")
                  (string-ref(lr sl(add1 i))0))
         #t #f ))
    (define cap   ; capital or not
      (if(or(= i 0)(contains(string->list ".!?")
                            (let ((prev (lr sl(sub1 i)))) (string-ref prev
                                       (sub1(string-length prev))))))
         #t #f))
    (set! sl(list-set sl i (if an (if cap "An" "an" )
                                 (if cap "A" "a")))))
  (string-join sl))

Так, для Ракетки! Дивіться також Поради щодо гольфу в ракетці / схемі
кіт

Це чудова мова, хоча і не призначена для гольфу.
rnso


1

Сітківка , 66 60 байт

i`\[\?\]( ([aeiou]?)[a-z&&[^aeiou])
a$.2*n$1
(^|[.?!] )a
$1A

Спробуйте в Інтернеті.

Пояснення:

Виконайте нечутливий до регістру пошук з [?]наступним голосним або приголосним, де необов'язковий голосний зберігається у групі захоплення 2 та весь збіг у групі 1 захоплення:

i`\[\?\]( ([aeiou]?)[a-z&&[^aeiou])

Замініть це на a, з наступною довжиною суми другої групи n(тобто 0 або 1 n), а потім літери (групи) групи захоплення 1:

a$.2*n$1

Тоді порівнюйте aабо на початку рядка, або після будь-якого з .?!плюс пробіл:

(^|[.?!] )a

І пропис великого регістру A, не видаляючи інших символів групи захоплення 1:

$1A

1

Java (JDK) , 154 байти

s->{String v="(?= [aeiou])",q="(?i)\\[\\?]",b="(?<=^|[?.!] )";return s.replaceAll(b+q+v,"An").replaceAll(q+v,"an").replaceAll(b+q,"A").replaceAll(q,"a");}

Спробуйте в Інтернеті!

Пояснення:

s->{
    String v="(?= [aeiou])",          // matches being followed by a vowel
    q="(?i)\\[\\?]",                  // matches being a [?]
    b="(?<=^|[?.!] )";                // matches being preceded by a sentence beginning
    return s.replaceAll(b+q+v,"An")   // if beginning [?] vowel, you need "An"
        .replaceAll(q+v,"an")         // if           [?] vowel, you need "an"
        .replaceAll(b+q,"A")          // if beginning [?]      , you need "A"
        .replaceAll(q,"a");}          // if           [?]      , you need "a"


0

Groovy, 73 162 байт

def a(s){s.replaceAll(/(?i)(?:(.)?( )?)\[\?\] (.)/){r->"${r[1]?:''}${r[2]?:''}${'.?!'.contains(r[1]?:'.')?'A':'a'}${'aAeEiIoOuU'.contains(r[3])?'n':''} ${r[3]}"}}

редагувати: чорт, капіталізація тут повністю ускладнила все


Чи це з великої літери на початку речення?
Тит

ніпе. Зараз я бачу, що опис виклику тим часом було змінено ...
norganos

"Дайте мені [?] Годину з [?] Відкритими дверима підвалу." Порушує
Magic Octopus Urn

опис виклику все ще повністю суперечливий. по-перше, він говорить: "Ви повинні турбуватися про капіталізацію!" і безпосередньо після цього з'являються правила капіталізації
Норганос

Це послідовно. Ви повинні турбуватися про капіталізацію (тобто вам потрібно керувати нею). Потім він пояснює, як
edc65

0

C # 209 байт

string A(string b){var s=b.Split(new[]{"[?]"},0);return s.Skip(1).Aggregate(s[0],(x,y)=>x+(x==""||(x.Last()==' '&&".?!".Contains(x.Trim().Last()))?"A":"a")+("AEIOUaeiou".Contains(y.Trim().First())?"n":"")+y);}

Відформатовано

string A(string b)
{
    var s = b.Split(new[] { "[?]" }, 0);
    return s.Skip(1).Aggregate(s[0], (x, y) => x + (x == "" || (x.Last() == ' ' && ".?!".Contains(x.Trim().Last())) ? "A" : "a") + ("AEIOUaeiou".Contains(y.Trim().First()) ? "n" : "") + y);
}

0

Perl 6 , 78 байт

{S:i:g/(^|<[.?!]>' ')?'[?] '(<[aeiou]>?)/{$0 xx?$0}{<a A>[?$0]}{'n'x?~$1} $1/}

Пояснення:

{
  S
    :ignorecase
    :global
  /
    ( # $0
    | ^             # beginning of line
    | <[.?!]> ' '   # or one of [.?!] followed by a space
    ) ?             # optionally ( $0 will be Nil if it doesn't match )

    '[?] '          # the thing to replace ( with trailing space )

    ( # $1
      <[aeiou]> ?   # optional vowel ( $1 will be '' if it doesn't match )
    )

  /{
    $0 xx ?$0      # list repeat $0 if $0
                   # ( so that it doesn't produce an error )
  }{
    < a A >[ ?$0 ] # 'A' if $0 exists, otherwise 'a'
  }{
    'n' x ?~$1     # 'n' if $1 isn't empty
                   # 「~」 turns the Match into a Str
                   # 「?」 turns that Str into a Bool
                   # 「x」 string repeat the left side by the amount of the right

  # a space and the vowel we may have borrowed
  } $1/
}

Тест:

#! /usr/bin/env perl6
use v6.c;
use Test;

my &code = {S:i:g/(^|<[.?!]>' ')?'[?] '(<[aeiou]>?)/{<a A>[?$0]~('n'x?~$1)} $1/}

my @tests = (
  'Hello, this is [?] world!'
  => 'Hello, this is a world!',

  'How about we build [?] big building. It will have [?] orange banana hanging out of [?] window.'
  => 'How about we build a big building. It will have an orange banana hanging out of a window.',

  '[?] giant en le sky.'
  => 'A giant en le sky.',

  '[?] yarn ball?'
  => 'A yarn ball?',

  '[?] hour ago I met [?] European.'
  => 'A hour ago I met an European.',

  "Hey sir [Richard], how 'bout [?] cat?"
  => "Hey sir [Richard], how 'bout a cat?",
);

plan +@tests;

for @tests -> $_ ( :key($input), :value($expected) ) {
  is code($input), $expected, $input.perl;
}
1..6
ok 1 - "Hello, this is a world!"
ok 2 - "How about we build a big building. It will have an orange banana hanging out of a window."
ok 3 - "A giant en le sky."
ok 4 - "A yarn ball?"
ok 5 - "A hour ago I met an European."
ok 6 - "Hey sir [Richard], how 'bout a cat?"

Чи можете ви видалити пробіл } $1в кінці (зробити його }$1)?
Cyoce

@Cyoce Існує спосіб зробити це, але це додає більше складності в інших місцях. {S:i:g/(^|<[.?!]>' ')?'[?]'(' '<[aeiou]>?)/{<a A>[?$0]~('n'x?~$1.substr(1))}$1/}
Бред Гілберт b2gills

Гаразд, я не був впевнений, як Perl
розбере

0

Луа, 131 байт.

function(s)return s:gsub("%[%?%](%s*.)",function(a)return"a"..(a:find("[AEIOUaeiou]")and"n"or"")..a end):gsub("^.",string.upper)end

Хоча Луа - це жахлива мова для гри в гольф, я відчуваю, що зробив досить добре.


0

Піп , 62 55 54 50 байт

Приймає рядок як аргумент командного рядка.

aR-`([^.?!] )?\[\?]( [^aeiou])?`{[b"aA"@!b'nX!cc]}

Спробуйте в Інтернеті!

Пояснення:

a                                                   Cmdline argument
 R                                                  Replace...
  -`                           `                    The following regex (case-insensitive):
    ([^.?!] )?                                      Group 1: not end-of-sentence (nil if it doesn't match)
              \[\?]                                 [?]
                   ( [^aeiou])?                     Group 2: not vowel (nil if there is a vowel)
                                {                }  ... with this callback function (b = grp1, c = grp2):
                                 [              ]   List (concatenated when cast to string) of:
                                  b                 Group 1
                                   "aA"@!b          "a" if group 1 matched, else "A"
                                          'nX!c     "n" if group 2 didn't match, else ""
                                               c    Group 2

0

Ракетка (з регулярним виразом) 228 байт

(define(r a b c)(regexp-replace* a b c))
(define(f s)
(set! s(r #rx"[a-zA-Z ]\\[\\?\\] (?=[aeiouAEIOU])"s" an "))
(set! s(r #rx"[a-zA-Z ]\\[\\?\\]"s" a"))
(set! s(r #rx"\\[\\?\\] (?=[aeiouAEIOU])"s"An "))
(r #rx"\\[\\?\\]"s"A"))

Тестування:

(f "[?] giant en le [?] sky.")
(f "[?] yarn ball?")
(f "[?] apple?")
(f "[?] hour ago I met [?] European. ")
(f "How about we build [?] big building. It will have [?] orange banana hanging out of [?] window.")
(f "Hello, this is [?] world!")

Вихід:

"A giant en le a sky."
"A yarn ball?"
"An apple?"
"A hour ago I met an European. "
"How about we build a big building. It will have an orange banana hanging out of a window."
"Hello, this is a world!"

0

Пітон 3 , 104 103 байти

-1 байт, без нагляду ]

lambda s:r('(^|[.?!] )a',r'\1A',r('a( [aeiouAEIOU])',r'an\1',r('\[\?]','a',s)));from re import sub as r

Спробуйте в Інтернеті!

Починається з заміни всіх випадків [?]на a,
Потім замінює всі, aза якими йде голосна, з an.
Потім замінює всі aна початку введення чи речення на A.

Припускає, що [?]ніколи не буде доторкатися до іншого слова, і цей малий регістр aніколи не повинен починати речення.


Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.