Wherre - суміжні символи в заголовку? [3, 4]!


21

Заголовок неправильно написаний. Читайте більше, щоб дізнатися чому.

Ваше завдання: надавши обмежений рядок або список, включаючи символи A,B,C,D, виведіть індекси всіх сусідніх рівних символів. Вихідним може бути декілька рядків / цілих чисел у кількох рядках, список / масив або обмежений рядок.

Весь вихід повинен бути у списку чи рядку, або декількох друкованих рядках. Кожен надрукований рядок, якщо їх декілька, повинен містити лише 1 рядок або число. Покірливі володарі добре.

Стандартні методи введення / виводу. Застосовуються стандартні лазівки.

Наприклад, вхід 'ABCDDCBA'повинен виводити 3,4або 4,5залежно від того, чи є він від 0 до 1-індексований, оскільки ці числа є індексами Dта Dнаступними до нього.

Тестові приклади:

Тестові приклади вводяться як один рядок, а вихідні - як ,розділений рядок. Виходи 0-індексовані, додайте 1 до кожного виведеного елемента, щоб він був 1-індексованим.

Input: 'ABCDCABCD'
Output: ''

Input: 'AABBCCDD'
Output: '0,1,2,3,4,5,6,7'

Input: 'ABCDDDCBA'
Output: '3,4,5'

Input: 'ABBCDD'
Output: '1,2,4,5'

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


Чи можемо ми мати вихідний роздільник на виході?
Ділова кішка

@BasicSunset Sure
Товариш SparklePony

1
@JonathanAllan Це нормально, оскільки він видає лише один список.
Товариш SparklePony

2
Чи можуть індекси послідовних символів відображатися кілька разів? Наприклад, для третього тестового випадку, чи 3,4,4,5справедливо також?
Лука

1
Чи можете ви додати тестовий випадок, у якому немає симетричних збігів? Напр.AABBCD -> 1,2,3,4
Райлі

Відповіді:


5

MATL , 8 7 байт

d~ftQvu

Результат 1-базований.

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

Пояснення на прикладі

Розглянемо вхід 'ABCDDDCBA'.

d     % Implicitly input a string. Consecutive differences
      % STACK: [1  1  1  0  0 -1 -1 -1]
~     % Negate. Each character that equals the next gives true
      % STACK: [0 0 0 1 1 0 0 0]
f     % Find: (1-based) indices of true elements
      % STACK: [4 5]
tQ    % Duplicate, add 1 element-wise
      % STACK: [4 5], [5 6]
v     % Concatenate vertically
      % STACK: [4 5; 5 6]
u     % Unique (remove duplicates). This doesn't automatically sort, but the 
      % output will be sorted because the input, read in column-major order, is 
      % Implicitly display
      % STACK: [4; 5; 6]

8

Сітківка , 33 29 23 байт

Збережено 6 байт завдяки Мартіну Ендеру

T`L`:`(.)\1+
:
$.`¶
T`L

Виводить список індексів, відокремлених від підведення даних.

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

Пояснення

T`L`:`(.)\1+

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

:
$.`¶

Потім замініть кожну двокрапку на довжину тексту перед нею, після чого слід подати рядок.

T`L

Нарешті, видаліть усі літери, що залишилися.


7

Желе , 7 байт

JṁŒgḊÐf

На основі 1; повертає список списків прогонів індексів , дозволених ОП.

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

Як?

JṁŒgḊÐf - Main link: char-list s       e.g. 'DCCABBBACCCD' (which is a python interpreted input of ['D','C','C','A','B','B','B','A','C','C','C','D'])
J       - range(length(s))                  [1,2,3,4,5,6,7,8,9,10,11,12]
  Œg    - group-runs(s)                     [['D'],['C','C'],['A'],['B','B','B'],['A'],['C','C','C'],['D']]
 ṁ      - mould left like right             [[1],[2,3],[4],[5,6,7],[8],[9,10,11],[12]]
     Ðf - filter keep items that would be truthy (empty is not truthy) after applying:
    Ḋ   -     dequeue (x[1:])               [    [2,3],    [5,6,7],    [9,10,11]     ]        

2
- Що б я хотів, щоб 05AB1E міг зробити за 500, будь ласка.
Чарівний восьминіг Урна

1
Я все більше і більше відчуваю, що ця мова начебто схожа на обман. : D
Avamander

@ComradeSparklePony, чому скасувати чек прийняття?
Джонатан Аллан

7

Мозок-Флак , 57 46 байт

{({}[({})]<(([]<>)[()])>){(<{}{}{}>)}{}<>}<>

Включає +2 для -ar

Використовує індексацію на основі 0.

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

# While true
{

  # Subtract the second value on the stack from the first
  ({}[({})]

  # Push the height of this stack (the main stack) on the other stack
  <(([]<>)

  # Push the height of the main stack - 1
  [()])>

  # Push the difference that we calculated a second ago
  )

  # If they weren't the same character
  {

    # Pop the difference and the two stack heights
    (<{}{}{}>)

  # End if
  }

  # Pop the difference (or the 0 to get out of the if)
  {}

# Switch back to the main stack and end while
<>}

# Switch to the stack with the indexes and implicitly print
<>

6

Математика, 32 байти

Union@@StringPosition[#,x_~~x_]&

Чиста функція, яка повертає 1-індексовані позиції символів, що примикають до ідентичного символу.

Пояснення:

StringPosition["string","sub"]подає список початкових і кінцевих позицій символів, на яких "sub"відображається як підрядка "string". x_~~x_- це StringExpressionзбіг двох суміжних, однакових символів. Наприклад, StringPosition["ABCDDDCBA",x_~~x_]дає {{4, 5}, {5, 6}}. Застосування Unionприєднується до списків, сортування та видалення дублікатів.


5

Мозг-Флак , 69, 59 , 56 байт

{({}[({})]<(())>){((<{}{}>))}{}{([{}]([]<>))(<>)}{}}<>

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

+2 байти для -arпрапорів, що дозволяє вводити ASCII і повертати стек.

Використовує індексацію на основі 0. Збережено 10 байт, зменшивши надмірність пуш-попу . Збережено ще 4 байти шляхом переключення з індексації на основі 1 на 0.

Це, в основному, єдиний виклик на основі струн, в якому добре спрацьовує мозок. Це тому, що головний мозок чудовий для порівняння послідовних персонажів, навіть якщо це взагалі жахливо при обробці рядків. Ось читабельна версія коду з коментарями, щоб пояснити, як він працює:

#While True
{

    #Determine if top two are equal
    ({}[({})]<(())>){((<{}{}>))}{}

    #If so
    {

        #Pop the one, and negate it's value (giving us -1)
        ([{}]

        #Push stack height over
        ([]<>)

        #Then push stack height plus the negated pop (-1)
        ) 

        #Push a zero back onto the main stack
        (<>)

    #Endwhile
    }

    #Pop the zero
    {}

#Endwhile
}

#Toggle back, implicitly display
<>


@riley виправлено! (І ще на один байт коротше: P)
DJMcMayhem

Я завжди про це забуваю -r. Це зводить мене до 46.
Райлі

5

Брахілог , 19 байт

l⟦k:?z{sĊtᵐ=∧Ċ∋h}ᶠd

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

Пояснення

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

Якщо false.є прийнятним результатом у випадках, коли суміжних символів немає, то це буде на 1 байт менше заміною ᶠdна .

l⟦k                      The list [0, …, length(Input) - 1]
   :?z                   Zip the Input with this list
      {         }ᶠd      Find with no duplicates:
            ∧Ċ∋h           The heads of each element of Ċ = [A, B] (i.e. the indexes)…
        Ċtᵐ=               …where the tails of both A and B are equal (i.e. the letters)…
       sĊ                  …and where Ċ = [A, B] is a substring of the Input


4

Cubix, 37 32 31 29 28 байт

Завдяки ETHProductions за вказівку мене в напрямку трибайтної економії

$uO@(;Usoi?-!w>;.....S_o\;#O

Спробуйте тут ! Зауважте, що показники виведення базуються на 1, а не у порядку зростання.

Розширено:

      $ u O
      @ ) ;
      U s o
i ? - ! w > ; . . . . .
S _ o \ ; # O . . . . .
. . . . . . . . . . . .
      . . .
      . . .
      . . .

Пояснення

Це працює, читаючи вхідний символ за символом. Для порівняння двох символів ми просто віднімаємо їхні символьні коди, і якщо результат дорівнює 0, ми друкуємо поточну довжину стека, пробіл, поточну довжину стека - 1 та інший пробіл. Потім трохи очищаємо стек, і знову починаємо з циклу читання. Якщо кінець вхідного рядка досягнуто, програма зупиняється.


Гм, якщо ви зможете зберегти стек досить чистим, можливо, ви зможете використовувати його, #щоб отримати довжину стека, коли вам це потрібно. (Також LOL'ed ;_;у коді;))
ETHproductions

Основний приклад (напевно, не повністю гольф); ethproductions.github.io/cubix/… (Примітка: це 1-індексований, а не 0-індексований)
ETHproductions

Дякуємо за нагадування. Я переграв один байт вашої версії і додав це. Мені, можливо, вдасться отримати інший байт або два відключення ...
Лука

Ідея: що робити, якщо ви зробили !$wзамість цього !wі перемістили частину логіки п'ятого ряду в четвертий ряд? (Не можу спробувати зараз, тому що я
пряму

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


3

C # , 115 байт


Гольф

i=>{var o="";for(int x=1,l=i.Length;x<=l;x++)o+=(x<l&&i[x]==i[x-1])||(x>1&&i[x-1]==i[x-2])?(x-1)+" ":"";return o;};

Безумовно

i => {
   var o = "";

   for( int x = 1, l = i.Length; x <= l; x++ )
      o += ( x < l && i[ x ] == i[ x - 1 ] ) || ( x > 1 && i[ x - 1 ] == i[ x - 2 ] )
         ? ( x - 1 ) + " "
         : "";

   return o;
};

Незрозумілий читабельний

i => {
   // List of positions
   var o = "";

   // Cycle through the string
   for( int x = 1, l = i.Length; x <= l; x++ )
      // Check if 'x' is below the string length
      //    and if the current and previous char are the same...
      //    ... or if 'x' is beyong the string length
      //    and the 2 previous chars are the same.
      o += ( x < l && i[ x ] == i[ x - 1 ] ) || ( x > 1 && i[ x - 1 ] == i[ x - 2 ] )

         // If true, add the index to the list of positions...
         ? ( x - 1 ) + " "

         // ...otherwise add nothing
         : "";

   // Return the list of positions.
   return o;
};

Повний код

using System;
using System.Collections.Generic;

namespace Namespace {
   class Program {
      static void Main( String[] args ) {
         Func<String, String> f = i => {
            // List of positions
            var o = "";

            // Cycle through the string
            for( int x = 1, l = i.Length; x <= l; x++ )
               // Check if 'x' is below the string length
               //    and if the current and previous char are the same...
               //    ... or if 'x' is beyong the string length
               //    and the 2 previous chars are the same.
               o += ( x < l && i[ x ] == i[ x - 1 ] ) || ( x > 1 && i[ x - 1 ] == i[ x - 2 ] )

                  // If true, add the index to the list of positions...
                  ? ( x - 1 ) + " "

                  // ...otherwise add nothing
                  : "";

            // Return the list of positions.
            return o;
         };

         List<String>
            testCases = new List<String>() {
               "ABCDCABCD",
               "AABBCCDD",
               "ABCDDDCBA",
               "",
               "A",
               "AA",
               "AAA",
         };

         foreach( String testCase in testCases ) {
            Console.WriteLine( $"{testCase}\n{f( testCase )}\n" );
         }

         Console.ReadLine();
      }
   }
}

Релізи

  • v1.0 - 115 bytes- Початкове рішення.

Примітки

Нічого додати



2

k, 18 байт

{?,/-1 0+/:&:=':x}

Приклади:

k){?,/-1 0+/:&:=':x}"AABCDDDCBAA"
0 1 4 5 6 9 10
k){?,/-1 0+/:&:=':x}"ABCDCBA"
()

Переклад на qлегший для розуміння:

{distinct raze -1 0+/:where not differ x}

Це було і моє початкове рішення! : D
згреп

2

JavaScript, 52 байти

Дякуємо @Neil за те, що ми граємо на 1 байт

x=>x.map((a,i)=>a==x[++i-2]|a==x[i]&&i).filter(a=>a)

Отримує вхід у вигляді 0-індексованого масиву символів
Повертає вихід у вигляді 1-індексованого масиву

Пояснення

x.map()

Для кожного символу в рядку

(a,i)=>(a==x[++i-2]|a==x[i])*i

Якщо він дорівнює попередньому символу або наступному символу, поверніть індекс + 1, інакше не повертайтеся (залишає невизначеним у масиві)

.filter(a=>a)

Видаліть усі неозначені елементи з отриманого масиву

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


Врятував &&iби байт (...)*i?
Ніл

@Neil && швидше, ніж |, що призведе до того, що він завжди повертається i
fəˈnɛtɪk

0|0&&6це 0, 1|0&&6це 6, 0|1&&6це 6, 1|1&&6це 6. Хіба це не те, що ти хочеш?
Ніл

Я думаю, я думав, що все ще маю || замість |
fəˈnɛtɪk

Ага так, це пояснило б це.
Ніл


1

Perl 5 , 37 байт

35 байт коду + plпрапори.

s/(?<=(.))\1|(.)(?=\2)/print pos/ge

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

(?<=(.))\1|(.)(?=\2)буде відповідати або між двома повторюваними символами ( (?<=(.))\1), або перед символом, який повторюється ( (.)(?=\2)).
Потім print posдрукує положення сірника. ( posмістить індекс поточної відповідності при використанні в регулярному вираженні з /gмодифікатором).





1

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

@set/ps=
@set/ai=c=0
:l
@if %s:~,1%==%s:~1,1% set c=2
@if %c% gtr 0 echo %i%
@set/ai+=1,c-=1
@if not "%s:~1%"=="" set s=%s:~1%&goto l

Здійснює введення даних STDIN. Працює, відслідковуючи кількість чисел для друку в cзмінній, яка скидається на 2 при виявленні пари. Примітка. При ціні 6 байт, можна посилити роботу з більшістю символів ASCII, а не тільки ABCD.


1

C #, 89 байт

using System.Linq;s=>string.Join("",s.Skip(1).Select((a,i)=>a==s[i]?i+" "+(i+1)+" ":""));

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

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

using System;
using System.Collections.Generic;
using System.Linq;

namespace Namespace
{
    class Class1
    {
        static void Main(string[] args)
        {
            Func<string, string> f2 =
                s => string.Join("" ,         //Combine the results into one string
                s.Skip(1)                     //Start with the second element
                .Select(
                    (a, i) =>                 // 'a' is the current element, 'i' is the index of the element in the result of 'Skip'
                    a == s[i] ?               // therefore 's[i]' is the previous element; compare it with the current one
                    i + " " + (i + 1) + " " : //If true, return the indexes
                    ""                        //Otherwise an empty string
                ));

            var tests = new string [] {
               "ABCDCABCD",
               "AABBCCDD",
               "ABCDDDCBA",
               "ABBCDD"
            };

            foreach (var test in tests)
            {
                Console.WriteLine(test);
                Console.WriteLine(string.Join("", f2(test)));
                Console.WriteLine();
            }

            Console.ReadLine();
        }
    }
}

1

QBIC , 42 байти

;[2,_lA||~mid$(A,a-1,1)=mid$(A,a,1)|?a-1,a

Вибірка зразка:

Command line: AADCDBBD
 1             2 
 6             7 

Пояснення:

;               Get A$ from the cmd line
[2,    |        FOR a% = 2 TO
   _lA|              the length of A$
~mid$(A,a-1,1)  IF the character at index a%
=mid$(A,a,1)    equals the char at index a%-1
|               THEN
?a-1,a          PRINT both indexes, tab-separated
                Any further doubles are printed on a separate line
                The IF and FOR are closed implicitly

EDIT: QBIC тепер має підрядку! Зараз це завдання можна вирішити в 32 байтах:

;[2,_lA||~_sA,a-1|=_sA,a||?a-1,a

Де:

_s      This is the substring function; it takes 1, 2 or 3 arguments. 
        Arguments are comma-seperated, the list is delimited with |
        In this answer we see Substring take 2 arguments:
  A,    The string to take from
    a|  Starting position (note:uppercase represents strings, lowercase is for nums)
        Any omitted argument (in this case 'length to take') is set to 1.

0

k, 14 байт

Це функція, вона займає рядок і повертає список індексів.

&{x|1_x,0}@=':

Пояснення:

           =': /compare each letter to the previous, return binary list
 {       }@    
    1_x,0      /shift left
  x|           /combine shifted and unshifted with binary or
&              /get indices of 1s

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

Як користуватись:

&{x|1_x,0}@=':"STRINGGOESHERE"

0

PHP, 70 байт

for(;a&$c=$argn[$i];)$i++&&$argn[$i-2]==$c||$argn[$i]==$c?print$i._:0;

приймає вхід від STDIN; бігати з -R.

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