Cel
Celem tego wyzwania jest: biorąc pod uwagę ciąg znaków, usuń zduplikowane pary liter, jeśli drugi element w parze ma przeciwne wielkie litery. (tzn. wielkie litery stają się małe i odwrotnie).
Pary należy wymieniać od lewej do prawej. Na przykład aAa
powinien zostać aa
i nie aA
.
Wejścia wyjścia:
Input: Output:
bBaAdD bad
NniIcCeE Nice
Tt eE Ss tT T e S t
sS Ee tT s E t
1!1!1sStT! 1!1!1st!
nN00bB n00b
(eE.gG.) (e.g.)
Hh3lL|@! H3l|@!
Aaa Aa
aaaaa aaaaa
aaAaa aaaa
Dane wejściowe składają się z drukowanych symboli ASCII.
Nie należy usuwać zduplikowanych cyfr ani innych znaków innych niż litery.
Potwierdzenie
To wyzwanie jest przeciwieństwem „Duplicate & switch case” @nicael . Czy możesz to odwrócić?
Dziękujemy za wszystkich współpracowników z piaskownicy!
Katalog
Fragment kodu na dole tego postu generuje katalog na podstawie odpowiedzi a) jako listy najkrótszych rozwiązań dla każdego języka oraz b) jako ogólnej tabeli wyników.
Aby upewnić się, że Twoja odpowiedź się pojawi, zacznij od nagłówka, korzystając z następującego szablonu Markdown:
## Language Name, N bytes
gdzie N
jest rozmiar twojego zgłoszenia. Jeśli poprawić swój wynik, to może zachować stare porachunki w nagłówku, uderzając je przez. Na przykład:
## Ruby, <s>104</s> <s>101</s> 96 bytes
Jeśli chcesz umieścić w nagłówku wiele liczb (np. Ponieważ twój wynik jest sumą dwóch plików lub chcesz osobno wymienić kary za flagi tłumacza), upewnij się, że rzeczywisty wynik jest ostatnią liczbą w nagłówku:
## Perl, 43 + 2 (-p flag) = 45 bytes
Możesz także ustawić nazwę języka jako link, który pojawi się we fragmencie:
## [><>](http://esolangs.org/wiki/Fish), 121 bytes
<style>body { text-align: left !important} #answer-list { padding: 10px; width: 290px; float: left; } #language-list { padding: 10px; width: 290px; float: left; } table thead { font-weight: bold; } table td { padding: 5px; }</style><script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script> <link rel="stylesheet" type="text/css" href="//cdn.sstatic.net/codegolf/all.css?v=83c949450c8b"> <div id="language-list"> <h2>Shortest Solution by Language</h2> <table class="language-list"> <thead> <tr><td>Language</td><td>User</td><td>Score</td></tr> </thead> <tbody id="languages"> </tbody> </table> </div> <div id="answer-list"> <h2>Leaderboard</h2> <table class="answer-list"> <thead> <tr><td></td><td>Author</td><td>Language</td><td>Size</td></tr> </thead> <tbody id="answers"> </tbody> </table> </div> <table style="display: none"> <tbody id="answer-template"> <tr><td>{{PLACE}}</td><td>{{NAME}}</td><td>{{LANGUAGE}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table> <table style="display: none"> <tbody id="language-template"> <tr><td>{{LANGUAGE}}</td><td>{{NAME}}</td><td>{{SIZE}}</td><td><a href="{{LINK}}">Link</a></td></tr> </tbody> </table><script>var QUESTION_ID = 85509; var ANSWER_FILTER = "!t)IWYnsLAZle2tQ3KqrVveCRJfxcRLe"; var COMMENT_FILTER = "!)Q2B_A2kjfAiU78X(md6BoYk"; var OVERRIDE_USER = 36670; var answers = [], answers_hash, answer_ids, answer_page = 1, more_answers = true, comment_page; function answersUrl(index) { return "//api.stackexchange.com/2.2/questions/" + QUESTION_ID + "/answers?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + ANSWER_FILTER; } function commentUrl(index, answers) { return "//api.stackexchange.com/2.2/answers/" + answers.join(';') + "/comments?page=" + index + "&pagesize=100&order=desc&sort=creation&site=codegolf&filter=" + COMMENT_FILTER; } function getAnswers() { jQuery.ajax({ url: answersUrl(answer_page++), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { answers.push.apply(answers, data.items); answers_hash = []; answer_ids = []; data.items.forEach(function(a) { a.comments = []; var id = +a.share_link.match(/\d+/); answer_ids.push(id); answers_hash[id] = a; }); if (!data.has_more) more_answers = false; comment_page = 1; getComments(); } }); } function getComments() { jQuery.ajax({ url: commentUrl(comment_page++, answer_ids), method: "get", dataType: "jsonp", crossDomain: true, success: function (data) { data.items.forEach(function(c) { if (c.owner.user_id === OVERRIDE_USER) answers_hash[c.post_id].comments.push(c); }); if (data.has_more) getComments(); else if (more_answers) getAnswers(); else process(); } }); } getAnswers(); var SCORE_REG = /<h\d>\s*([^\n,<]*(?:<(?:[^\n>]*>[^\n<]*<\/[^\n>]*>)[^\n,<]*)*),.*?(\d+)(?=[^\n\d<>]*(?:<(?:s>[^\n<>]*<\/s>|[^\n<>]+>)[^\n\d<>]*)*<\/h\d>)/; var OVERRIDE_REG = /^Override\s*header:\s*/i; function getAuthorName(a) { return a.owner.display_name; } function process() { var valid = []; answers.forEach(function(a) { var body = a.body; a.comments.forEach(function(c) { if(OVERRIDE_REG.test(c.body)) body = '<h1>' + c.body.replace(OVERRIDE_REG, '') + '</h1>'; }); var match = body.match(SCORE_REG); if (match) valid.push({ user: getAuthorName(a), size: +match[2], language: match[1], link: a.share_link, }); else console.log(body); }); valid.sort(function (a, b) { var aB = a.size, bB = b.size; return aB - bB }); var languages = {}; var place = 1; var lastSize = null; var lastPlace = 1; valid.forEach(function (a) { if (a.size != lastSize) lastPlace = place; lastSize = a.size; ++place; var answer = jQuery("#answer-template").html(); answer = answer.replace("{{PLACE}}", lastPlace + ".") .replace("{{NAME}}", a.user) .replace("{{LANGUAGE}}", a.language) .replace("{{SIZE}}", a.size) .replace("{{LINK}}", a.link); answer = jQuery(answer); jQuery("#answers").append(answer); var lang = a.language; lang = jQuery('<a>'+lang+'</a>').text(); languages[lang] = languages[lang] || {lang: a.language, lang_raw: lang.toLowerCase(42), user: a.user, size: a.size, link: a.link}; }); var langs = []; for (var lang in languages) if (languages.hasOwnProperty(lang)) langs.push(languages[lang]); langs.sort(function (a, b) { if (a.lang_raw > b.lang_raw) return 1; if (a.lang_raw < b.lang_raw) return -1; return 0; }); for (var i = 0; i < langs.length; ++i) { var language = jQuery("#language-template").html(); var lang = langs[i]; language = language.replace("{{LANGUAGE}}", lang.lang) .replace("{{NAME}}", lang.user) .replace("{{SIZE}}", lang.size) .replace("{{LINK}}", lang.link); language = jQuery(language); jQuery("#languages").append(language); } }</script>
abB
:?abB
czyab
?abB
powinien wypisaćab
aa
;aA
;AA
, tylko środkowa para pasuje do wzoru i staje sięa
, więcaa
;a
;AA
Odpowiedzi:
Galaretka , 8 bajtów
Wypróbuj online! lub zweryfikuj wszystkie przypadki testowe .
Jak to działa
źródło
Siatkówka , 18 bajtów
Wypróbuj online!
Wyjaśnienie
Jest to pojedyncze (i dość proste) podstawienie, które pasuje do odpowiednich par i zastępuje je tylko pierwszą postacią. Pary są dopasowywane przez aktywację rozróżniania wielkości liter w połowie wzoru:
Zastąpienie po prostu odpisuje postać, którą już złapaliśmy w grupie
1
.źródło
Brachylog , 44 bajty
Brachylog nie ma wyrażeń regularnych.
Wyjaśnienie
źródło
C #,
8775 bajtówZ potężnym regexem Martina Endera. C # lambda, gdzie znajdują się dane wejściowe i wyjściowe
string
.12 bajtów zapisanych przez Martina Endera i TùxCräftîñga.
C #,
141134 bajtówC # lambda, gdzie znajdują się dane wejściowe i wyjściowe
string
. Algorytm jest naiwny. Tego używam jako odniesienia.Kod:
7 bajtów dzięki Martinowi Enderowi!
Wypróbuj je online!
źródło
Perl,
4024 + 1 = 25 bajtówUżyj tego samego wyrażenia regularnego co Martin.
Użyj
-p
flagiPrzetestuj na ideonie
źródło
Python 3,
645958 bajtówPrzetestuj na Ideone .
źródło
C, 66 bajtów
źródło
Pyth,
2420 bajtów4 bajty dzięki @Jakube.
Nadal używa wyrażeń regularnych, ale tylko do tokenizacji.
Zestaw testowy.
źródło
JavaScript (ES6),
7168 bajtówWyjaśnienie:
Biorąc pod uwagę
c>'@'
, jedynym sposobem,parseInt(c+l,36)
aby być wielokrotnością liczby 37, jest obojec
il
mieć tę samą wartość (nie mogą mieć wartości zerowej, ponieważ wykluczyliśmy spację i zero, a jeśli nie mają żadnej wartości, wyrażenie oceni,NaN<1
która jest false) oznacza, że mają być tą samą literą. Wiemy jednak, że wielkość liter nie jest rozróżniana, więc muszą być rozróżniani.Zauważ, że ten algorytm działa tylko wtedy, gdy sprawdzę każdy znak; jeśli spróbuję to uprościć, dopasowując litery, to nie powiedzie się na przykładach
"a+A"
.Edycja: Zapisano 3 bajty dzięki @ edc65.
źródło
`
jeśli używamreplace
. (Miałem tylko je przed starać się być spójne, ale potem grałem moją odpowiedź podczas edycji składania i stał się ponownie niezgodne Ech ....)C,
129127125107106105939290888578 bajtówPort AC mojej odpowiedzi C # . Moje C może być trochę złe. Często nie używam tego języka. Każda pomoc jest mile widziana!
a!=b
=a^b
a&&b
=a*b
(c|32)==(d|32)
problem bitowyKod:
Wypróbuj online!
źródło
f(char*s){while(*s) {char c=*s,d=s+1;putchar(c);s+=isalpha(c)&&d&&((c|32)==(d|32)&&c!=d);}}
s+++1
na++s
.c
id
zawsze będzie można wydrukować ASCII, więc95
powinno działać zamiast~32
. Myślę też, żec;d;f(char*s){for(;*s;){putchar(c=*s);s+=isalpha(c)*(d=*(++s))&&(!((c^d)&95)&&c^d);}}
zadziałałoby (ale nie zostało przetestowane).MATL , 21 bajtów
Wypróbuj online! . Lub sprawdź wszystkie przypadki testowe .
Wyjaśnienie
Przetwarza to każdy znak w pętli. Każda iteracja porównuje obecną postać z poprzednią postacią. Ten ostatni jest przechowywany w schowku K, który jest
4
domyślnie inicjowany.Obecny znak jest porównywany z poprzednim dwukrotnie: najpierw bez rozróżniania wielkości liter, a następnie z rozróżnianiem wielkości liter. Obecny znak powinien zostać usunięty tylko wtedy, gdy pierwsze porównanie było prawdziwe, a drugie fałszywe. Zauważ, że ponieważ schowek K początkowo zawiera 4, pierwszy znak zawsze zostanie zachowany.
Jeśli bieżący znak zostanie usunięty, schowek K powinien zostać zresetowany (aby następny znak został zachowany); w przeciwnym razie powinien zostać zaktualizowany o obecną postać.
źródło
Java 7, 66 bajtów
Wykorzystał regex Martina Endera z odpowiedzi Retina .
Kod niepoznany i testowy:
Wypróbuj tutaj.
Wydajność:
źródło
JavaScript (ES6),
61 bajtów, 57 bajtóws=>s.replace(/./g,c=>l=c!=l&/(.)\1/i.test(l+c)?'':c,l='')
Podziękowania dla Neila za oszczędność 5 bajtów.
źródło
s=>s.replace(/./g,c=>l=c!=l&/(.)\1/i.test(l+c)?'':c,l='')
"code".length
, nie zdawałem sobie sprawy, że jest tam sekwencja ucieczki. Dzięki(code).toString().length
.(code+"").length
JavaScript (ES6) 70
źródło
===
?0==""
ale nie0===""
@NeilWypukły, 18 bajtów
Wypróbuj online!
Podobne podejście jak w Pyth @Leaky Nun . Konstruuje tablicę
["aA" "bB" ... "zZ" "Aa" "Bb" ... "Zz" '.]
, łączy'|
znak i testuje dane wejściowe na podstawie tego wyrażenia regularnego. Następnie bierze pierwszą postać każdego meczu.źródło