Краще пізно, ніж ніколи!


12

Ваша програма / функція тощо займе 2 входи. Першим буде список того, хто прийшов на мою вечірку і коли. Приклад:

Kevin 13:02  
Ruby 5  
Sam 3  
Lisa 6  
Bob 12  

Що це означає? Це означає, що Кевін потрапив на мою вечірку спочатку (о 13:02, 24-годинний час), потім Рубі через 5 хвилин, потім Сем через 3 хвилини, потім Ліза через 6 хвилин, і останній Боб через 12 хвилин.

Другий вхід буде, коли розпочалася моя партія. Приклад:

13:15

(24-годинний час). Вихід повинен бути списком людей, які запізнилися. (Кожен точно вчасно добре). Приклад розрахунків (тільки наприклад, не виводити їх)

Kevin 13:02
Ruby 13:07
Sam 13:10
Lisa 13:16
Bob 13:28

Ліза і Боб приїхали після 13:15, тому ця програма повинна надрукувати "Лізу, Боб".

Вхідні припущення

  • Введенням 1 завжди буде ім’я (регулярний вираз [A-Z][a-z]*), потім пробіл, а потім 24 години у форміhours:minutes на першому рядку, потім ім'ям, пробілом та додатним цілим числом (кількість хвилин пізніше) у наступних рядках . Завжди буде принаймні 1 рядок.
  • Якщо ви хочете, ви можете взяти вхід 1 з будь-яким іншим символом замість розриву рядка.
  • Введення 2 буде у форматі hours:minutes .
  • Ви можете сприймати свої дані як одну рядок, розділену будь-яким символом, якщо хочете. Це необов’язково.
  • Не хвилюйтесь про денний кросовер. Мої вечірки ніколи не пізніше 23:59.

Правила виведення

  • Вихідним може бути значення функції, що повертається, або рядок, що перегукується з STDIN, файлом тощо. Ви повинні повернути рядок або масив / список.
    • Якщо ви повернете рядок, це повинен бути кожен, хто запізнився (наказ не має значення), відокремлений будь-яким не буквено-цифровим роздільником.
    • Якщо ви повернете масив / список, це повинен бути список усіх, хто запізнився.

2
Чи потрібен строгий формат введення? Чи може, наприклад, першим входом бути список списків, кожен з яких є "рядком", що містить два елементи даних?
Джонатан Аллан

"Вхід 1 завжди буде іменем (regex [A-Z][a-z]*)" Це говорить про те, що імена можуть бути порожніми?
HyperNeutrino

2
Я припускаю, що ви мали на увазі "так, необхідний строгий формат введення".
Джонатан Аллан

2
Суворий формат введення робить цей виклик менш цікавим
Луїс Мендо

3
"Мої вечірки ніколи не після 11:59". ти маєш на увазі 23:59?
tsh

Відповіді:


3

MATL , 31 байт

jYb1L&)1&)XUYs1440/0whwYO+jYO>)

Перший вхід використовує простір замість розриву рядка (дозволений викликом).

Вихідні дані використовують розрив рядка як роздільник.

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

Пояснення

j       % Input first string
Yb      % Split at spaces. Gives cell array of strings
1L&)    % Separate into subarrays with odd and even indices. Odd are names, even
        % are time and increments in minutes
1&)     % Separate the subarray of even indices into first entry and remaining
        % entries. The first is a string representing the time of first arrival,
        % the rest are strings representing increments in minutes
XU      % Convert strings representing increments into the actual numbers
Ys      % Cumulative sum
1440/   % Divide by 1440 (number of minutes in a day)
0wh     % Prepend a 0
w       % Swap. Bring the string with time of first arrival to the top
YO      % Convert to serial date number. Fractional part indicates time
+       % Add. This gives all arrivals as serial date numbers
j       % Input second string
YO      % Convert to serial date number
>       % Less than?, element-wise
)       % Index: select the names for which the comparison gave true
        % Implicitly display

6

JavaScript (ES6), 98 97 байт

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

Приймає список гостей lта час вечірки hу синтаксисі каррі (l)(h). Очікує в списку кінцеву лінію рядків. Повертає розділений пробілом список імен, таких як Lisa Bob.

l=>h=>l.replace(/(.* )(.*)\n/g,(_,a,b)=>(t-=T(b))<0?a:'',t=(T=h=>eval(h.replace(/:/,'*60+')))(h))

Відформатовано та прокоментовано

l => h =>                         // given a list of guests l and a party time h
  l.replace(                      // for each guest in l:
    /(.* )(.*)\n/g,               //   extract the name a and arrival time b
    (_, a, b) =>                  //   subtract the arrival time from the time counter
      (t -= T(b)) < 0 ?           //   if the result is negative:
        a                         //     the guest is late: keep the name
      :                           //   else:
        '',                       //     the guest is on time: remove this entry
    t = (                         //   initialize the time counter t
      T = h =>                    //   define T():
        eval(                     //     a function that takes either a time
          h.replace(/:/, '*60+')  //     in hh:mm format or an amount of minutes
        )                         //     and returns an amount of minutes   
    )(h)                          //   call it with the party time
  )                               // end of replace()

Демо

let f =

l=>h=>l.replace(/(.* )(.*)\n/g,(_,a,b)=>(t-=T(b))<0?a:'',t=(T=h=>eval(h.replace(/:/,'*60+')))(h))

console.log(f(`Kevin 13:02
Ruby 5
Sam 3
Lisa 6
Bob 12
`)('13:15'))


Розумне рішення! +1. Моя дорога далеко ....... :(
Арджун

Не (.*) (.*)\nпрацює?
Ніл

@Neil За замовчуванням жадібний, перший (.*)відповідатиме всій лінії.
Арнольд

Тоді що б відповідало космосу?
Ніл

@Neil О, вибачте, ти маєш рацію.
Арнольд

6

PHP, 118 98 95 91 байт

while($n=$argv[++$i])$i&1?$p=$n:($t=($f=strtotime)($n)?:$t+60*$n)<=$f(end($argv))?:print$p;

приймає дані з аргументів командного рядка (ви можете інтерпретувати це як рядки, розділені пробілами, якщо вам подобається); друкує імена без роздільника. Запустіть -rабо випробуйте його в Інтернеті .

редагувати 1: збережено 20 байт при прямому друку
редагувати 2: збережено 3 байти, видаливши роздільник
3 редагування: збережено 4 байти, використовуючи, що прості цілі числа не є дійсними датами дляstrtotime

зламатися

while($n=$argv[++$i])       # loop through arguments, skip [0]
    $i&1                        # if index is odd   
    ?   $p=$n                   # then assign name to $p
    :   ($t=                    # else $t =
        ($f=strtotime)($n)          # if $n is a valid time, parse it
        ?:$t+60*$n                  # else add $n minutes to current $t
        )<=$f(end($argv))           # if $t <= parsed party start
        ?                           # then do nothing
        :print$p;                   # else print name


5

JavaScript ES6, 185 байт

l=>t=>l.split`
`.map(p=>p.split` `).map((p,i,a)=>[p[0],i?d(a[0][1])+a.slice(1,i+1).reduce((a,p)=>a+=+p[1],0)*6e4:(d=x=>Date.parse(`2017T${x}`))(p[1])]).filter(p=>p[1]>d(t)).map(p=>p[0])

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

const f = l=>t=>l.split`
`.map(p=>p.split` `).map((p,i,a)=>[p[0],i?d(a[0][1])+a.slice(1,i+1).reduce((a,p)=>a+=+p[1],0)*6e4:(d=x=>Date.parse(`2017T${x}`))(p[1])]).filter(p=>p[1]>d(t)).map(p=>p[0])


console.log(f('Kevin 13:02\nRuby 5\nSam 3\nLisa 6\nBob 12')('13:15'))


Наскільки я можу сказати з специфікації, форма введення може бути більш суворою.
Джонатан Аллан

Я думаю, це зараз правильно.
порошків

Так - я також запитав про строгість введення.
Джонатан Аллан

... насправді у вас є час, який ви маєте на увазі, а не компенсації, які це має бутиf('Kevin 13:02\nRuby 5\nSam 3...
Джонатан Аллан

1
@JonathanAllan Дякую Зрозумів зараз.
порошки

4

PowerShell , 215 196 180 байт

param($a,$b)$x,[array]$a=$a-split',';$z=@{};$i,$j=-split$x;$z[$i]=($y=date $j);0..($a.count-1)|%{$i,$j=-split$a[$_];$z[$i]=($y=$y|% *es $j)};($z|% *or|?{$_.value-gt(date $b)}).Name

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

Приблизно 1/3 цього є вхідним аналізом, тож я не впевнений, наскільки далі я можу гольфувати його.

Вводиться $aяк введення рядків з іменами та часом / хвилинами, а $bтакож hh:mmяк рядок. По- перше, ми -split $aна ,, зберегти перший результат в $xа решту в $a, з явною повторної складу $aяк array(так, щоб петля пізніше працює належним чином). Ми, форматувати наш хеш $z, набір $iі $jбути $x -splitна пробільних і безліч $z[$i]бути dateз $j(що зберігається в$y для подальшого використання).

Потім пров'язуємо через решту $a. Кожну ітерацію ми робимо аналогічно - -splitрядок на пробілі, встановлюємо відповідний $zіндекс таким, який буде набагато більше хвилин за межами, де ми зараз перебуваємо. Для використання цього скороченого трюку з іменем властивості зберігається кілька байт, використовуючи |% *es $jзамість .AddMinutes($j).

Нарешті, ми .GetEnumerator()(знову - таки з допомогою трюку) нашої Hashtable, і Where-Objectвибрати ті записи , з valueцим -gля більшої tхань $b(тобто, вони запізнилися на вечірку). Потім вибираємо лише .Nameїх. Вихід - це неявний масив, в який за замовчуванням Write-Outputвставляються нові рядки між ними.

Врятували купу завдяки брианісту за те, що він нагадав мені, що [масив] - це річ. І ще купок для скороченої підказки щодо власності.


Зізнаюся, я прочитував і перевіряв це мінімально, але чи не могли ви просто так зробити$x,[array]$a=$a-split',' ?
британіст

1
@briantist Так, дякую. Я постійно намагався знайти спосіб використання оператора комами у множині призначення, і це просто не працювало. Я зовсім забув, що [array]це дійсний акторський склад. Ха-ха. Дуже багато гольфу, я думаю.
AdmBorkBork

Я на мобільному телефоні , так поза буде важко перевірити , але я думаю , що GetEnumeratorі AddMinutesє хорошими кандидатами для %методу синтаксису
briantist

@briantist Так. Економить ще 16. Дякую!
AdmBorkBork

4

Python 2 , 140,148, 144 байт

t,h,n=map(str.split,input().replace(':','').split(';')),100,0
for a,v in t[:-1]:
 n+=int(v)
 if n%h/60:n=n/h*h+n%h%60+h
 if`n`>t[-1][0]:print a,

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

Формат введення:

'Kevin 13:02;Ruby 5;Sam 3;Lisa 6;Bob 12;13:15'

Неправильно справляється з хвилинним переповненням: 'Kevin 13:47;Ruby 5;Sam 3;Lisa 6;Bob 12;14:00'нічого не друкує, навіть якщо Ліза та Боб все ще спізнюються.
L3viathan

1
о так. Відбувся глюк! Виправлено це. Дякую!
Кеертана Прабхакаран


3

CJam, 66 54 58 54 51 49 46 байт

{{':/60b}:K~)rSrKs++q+S/2/z~:i[{1$+}*]2$+$@#>}

Вхід 1 подається через STDIN, вхід 2 подається як рядок на стеку. Вихід - це масив стека. Сепаратор для входу 1 - це пробіл, наприкладKevin 13:02 Ruby 5 Sam 3 Lisa 6 Bob 12 .

Слід стека:

         e# Stack:               | "13:15"
{        e# Define K and run it:
  ':/    e#   Split on colon:    | ["13" "15"]
  60b    e#   From base 60:      | 795
}:K~     e# End def
)        e# Increment:           | 796
r        e# Read token:          | 796 "Kevin"
S        e# Push space:          | 796 "Kevin" " "
r        e# Read another token:  | 796 "Kevin" " " "13:02"
K        e# K()                  | 796 "Kevin" " " 782
s        e# Convert to string:   | 796 "Kevin" " " "782"
++       e# Add together:        | 796 "Kevin 782"
q        e# Read rest of input:  | 796 "Kevin 782" " Ruby 5 Sam 3 Lisa 6 Bob 12"
+        e# Add together:        | 796 "Kevin 782 Ruby 5 Sam 3 Lisa 6 Bob 12"
S/       e# Split on spaces:     | 796 ["Kevin" "782" "Ruby" "5" "Sam" "3" "Lisa" "6" "Bob" "12"]
2/       e# Group by 2:          | 796 [["Kevin" "782"] ["Ruby" "5"] ["Sam" "3"] ["Lisa" "6"] ["Bob" "12"]]
z        e# Transpose:           | 796 [["Kevin" "Ruby" "Sam" "Lisa" "Bob"] ["782" "5" "3" "6" "12"]]
~        e# Unpack:              | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] ["782" "5" "3" "6" "12"]
:i       e# Convert all to int:  | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] [782 5 3 6 12]
[{1$+}*] e# Accumulate:          | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] [782 787 790 796 808]
2$       e# Copy back element:   | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] [782 787 790 796 808] 796
+        e# Add into array:      | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] [782 787 790 796 808 796]
$        e# Sort:                | 796 ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] [782 787 790 796 796 808]
#        e# Find index:          | ["Kevin" "Ruby" "Sam" "Lisa" "Bob"] 3
>        e# Slice:               | ["Lisa" "Bob"]

Пояснення:

  • Процедура Kперетворюється між часомhh:mm і числом, що представляє скільки хвилин, що пройшло з півночі.
  • Ми читаємо першу людину і замінюємо їх час на K (їх час). Потім додаємо це на передню частину вводу.
  • Потім ми заздалегідь виконуємо деякі рядкові операції, щоб отримати список імен та список разів [782 5 3 6 12].
  • Накопичуючи цей список, ми отримуємо [782 787 790 796 808], що дає час, який усі прийшли.
  • Найкоротший спосіб знайти того, хто запізнюється, - це вставити час початку в масив, а потім пересортувати його, щоб розмістити його там, де він повинен бути. Потім ми знаходимо індекс, щоб визначити, де він розміщений, а потім нарізаємо список імен із цього індексу.

2

JavaScript, 285 283 байт

Приймає список гостей iта час вечірки pу синтаксисі каррі (i)(p). Повертає розділений комою список імен, таких як Lisa,Bob.

i=>p=>{n=i.split`
`,a=new Date(0,0,0,...n[0].split` `[1].split`:`),y=new Date(0,0,0,...p.split`:`),t=[a];w=a;n.slice(1).map((j,k,l)=>{h=l[k].split` `[1]*6e4;t.push(new Date(w.getTime()+h));w=new Date(w.getTime()+h)});return n.filter((j,k,l)=>t[k]>y).map(j=>j.split` `[0]).join()}

Я знаю, що це досить довго і зараз на останньому місці по справедливій запасі, але це те, що я міг би придумати.

f=i=>p=>{n=i.split`
`,a=new Date(0,0,0,...n[0].split` `[1].split`:`),y=new Date(0,0,0,...p.split`:`),t=[a];w=a;n.slice(1).map((j,k,l)=>{h=l[k].split` `[1]*6e4;t.push(new Date(w.getTime()+h));w=new Date(w.getTime()+h)});return n.filter((j,k,l)=>t[k]>y).map(j=>j.split` `[0]).join()}

console.log(f(`Kevin 13:02
Ruby 5
Sam 3
Lisa 6
Bob 12
`)('13:15'))


2

C # , 269 267 байт


Гольф

(l,t)=>{var h=System.DateTime.MinValue;var s=System.DateTime.ParseExact(t,"HH:mm",null);var o="";foreach(var p in l.Split('\n')){var i=p.Split(' ');h=h.Ticks<1?System.DateTime.ParseExact(i[1],"HH:mm",null):h.AddMinutes(int.Parse(i[1]));if(h>s)o+=i[0]+" ";}return o;};

Безумовно

( l, t ) => {
   var h = System.DateTime.MinValue;
   var s = System.DateTime.ParseExact( t, "HH:mm", null );
   var o = "";

   foreach( var p in l.Split( '\n' ) ) {
      var i = p.Split( ' ' );

      h = h.Ticks < 1
         ? System.DateTime.ParseExact( i[ 1 ], "HH:mm", null )
         : h.AddMinutes( int.Parse( i[ 1 ] ) );

      if( h > s )
         o += i[ 0 ] + " ";
   }

   return o;
};

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

( l, t ) => {
   // var to check the time of arrival
   var h = System.DateTime.MinValue;

   // var to store the start time of the party
   var s = System.DateTime.ParseExact( t, "HH:mm", null );

   // var with the names of those who arrived late
   var o = "";

   // Cycle through which line
   foreach( var p in l.Split( '\n' ) ) {
      // Split the name and time
      var i = p.Split( ' ' );

      // Check if the time of arrival still has the initial value
      h = h.Ticks < 1

         // If so, grab the time of the first person
         //   Expects to have a time format of 'hh:mm'
         ? System.DateTime.ParseExact( i[ 1 ], "HH:mm", null )

         // Otherwise, add the difference to the var
         : h.AddMinutes( int.Parse( i[ 1 ] ) );

      // Check if the current time is later than the party start time
      if( h > s )

         // If so, add the name to the list
         o += i[ 0 ] + " ";
   }

   // Return the names of the persons who arrived late
   return o;
};

Повний код

using System;
using System.Collections.Generic;

namespace Namespace {
   class Program {
      static void Main( String[] args ) {
         Func<String, String, String> f = ( l, t ) => {
            var h = System.DateTime.MinValue;
            var s = System.DateTime.ParseExact( t, "HH:mm", null );
            var o = "";

            foreach( var p in l.Split( '\n' ) ) {
               var i = p.Split( ' ' );

               h = h.Ticks < 1
                  ? System.DateTime.ParseExact( i[ 1 ], "HH:mm", null )
                  : h.AddMinutes( int.Parse( i[ 1 ] ) );

               if( h > s )
                  o += i[ 0 ] + " ";
            }

            return o;
         };

         List<KeyValuePair<String, String>>
            testCases = new List<KeyValuePair<String, String>> {
               new KeyValuePair<String, String>(
                  "Kevin 13:02\nRuby 5\nSam 3\nLisa 6\nBob 12",
                  "13:15"
               ),
               new KeyValuePair<String, String>(
                  "Kevin 13:15\nRuby 5\nSam 3\nLisa 6\nBob 12",
                  "13:15"
               ),
            };

         foreach( KeyValuePair<String, String> testCase in testCases ) {
            Console.WriteLine( $" Input:\n{testCase.Key}\n\n{testCase.Value}\n\nOutput:\n{f( testCase.Key, testCase.Value )}\n" );
         }

         Console.ReadLine();
      }
   }
}

Релізи

  • v1.1 - - 2 bytes- Завдяки VisualMelon
  • v1.0 - 269 bytes- Початкове рішення.

Примітки

  • Формат виводу: виводить імена, розділені пробілами

Ви можете зберегти кілька байт, додавши using D=System.DateTime;директиву (не забудьте замінити vars!). Вам слід дійсно надати типи лямбда-параметрів, щоб зробити цей код абсолютно однозначним (тобто (string l,string f)). Я також думаю, що є невелика помилка, вам потрібна h>sшвидше, ніж h>=s(економія 1байта!) Відповідно до "(будь-хто точно вчасно.)". Можна зробити h.Ticks<1? Ви можете знайти нульовий DateTimeдешевший, ніж використання DateTime.Min, але тут я не перевірив повних наслідків. З використанням пункту, також ==D.Minповинен працювати.
VisualMelon

Щодо використання я сумніваюся, що все-таки я міг би витягнути лямбда-вираз із ним. Я впевнений, що не можу додати його в середньому коді . Явні лямбда-типи - це ще одна річ, яку я не бачив, як люди це роблять, і я пішов з цим - якщо це незаконно , скажіть так, але навіть модники нічого не сказали, можливо, це добре? h>sЯ зроблю це. h.Ticks<1і цей теж.
auhmaan

Я впевнений, що ми дозволяємо usingsі таке з лямбдами, я не можу знайти що-небудь чітко сказати про це мета, але це питання напевно пропонує, що це дозволено. Існує обгрунтований консенсус щодо необхідності явних типів параметрів (я повинен додати, що я твердо прихильний). Між іншим, модники є для того, щоб тримати речі цивільні з точки зору SE, а не виконувати власні правила PPCG.
VisualMelon

Я свого роду проти usings, здебільшого тому, що тоді я відчував би, що це потребує повного коду, отже, кажу, що я сумніваюся, що я можу зняти функцію як рішення - можливо, додавши два блоки, один для usings та інший для лямбда-функція? Щодо консенсусу, я думаю, додавання пропущеного Func<...> f = ...;вирішить це, хоча слід вказати повне ім'яSystem.Func<...> f = ...;
auhmaan

Вам може бути краще просто мати добре названу функцію (додає лише string sсинтаксис C # 7 (6? Я не пам'ятаю)), якщо ви хочете не змішувати лямбда і вжинки.
VisualMelon

2

CJam , 43 41 байт

q~':/60b:Y;Sf/()':/60b+a\+{)iT+:TY>{;}|}%

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

Пояснення

q~        e# Read and eval all input.

':/       e# Split the start time on colons.
60b       e# Convert the result from base 60, to get the start time in minutes.
:Y;       e# Store this time in variable Y, and discard it from the stack.

Sf/       e# Split each string in the guest list on spaces.
(         e# Pull out the first guest from the list.
)         e# Pull out the time from the guest.
':/60b+   e# Convert the time to a number of minutes (same way as before), then add it back
          e#   to the guest.
a\+       e# Add the guest back to the start of the guest list.

          e# At this point, the first guest has his/her arrival time in minutes, and everyone
          e#  else still has their original number.

{         e# Apply this block to each guest:
 )i       e#  Pull out the number and cast it to an integer.
 T+       e#  Add the value of variable T to it (T is initially 0).
 :T       e#  Store the result back into T.
 Y>{;}|   e#  If the resulting number of minutes is not after the start time, delete the 
          e#    guest's name.
}%        e# (end of block)

          e# Implicit output.

2

Луа, 211 206 байт

Перший кодовий гольф року для мене все ще повинен бути гофрованим.

Редагувати: збережено 5 байт за допомогою скорочення для string.match

function f(l,T)m=T.match
r=function(X)return
m(X,"^%d+")*3600+60*m(X,"%d+$")end
T=r(T)z={}y=0
for i=1,#l do
h=m(l[i],"%d.*")h=i>1 and y+h*60or r(h)y=h
z[#z+1]=h>T and m(l[i],"%u%l*")or nil
end return z end

Пояснення

function f(l,T)                         -- declare the function f(list,partyTime)
  r=function(X)                         -- declare a function r that convert hh:mm in seconds
    return X:match("^%d+")*3600         -- return the sum of seconds the hours
          +60*X:match("%d+$")           -- and in the seconds
  end                                   
  T=r(T)                                -- convert the partyTime in seconds
  z={}                                  -- create the shameList for late partygoers
  y=0                                   -- y will keep us updated on the second count
  for i=1,#l                            -- iterate over l
  do                                    
    h=l[i]:match("%d.*")                -- h is a shorthand for the time of arrival
    h=i>1                               -- if we're on the second line at least
        and y+h*60                      -- update h with the time of arrival in second
      or r(h)                           -- else use r()(for the first partygoer only)
    y=h                                 -- update our reference for adding time
    z[#z+1]=h>T                         -- if the last partygoer was late
                and l[i]:match("%u%l*") -- add its name to the shameList
              or nil                    -- else, don't do anything
  end                                   
  return z                              -- return the shameList
end                                 

якщо ви хочете спробувати цей код, ви можете скористатися наступним фрагментом

function f(l,T)r=function(X)return
X:match("^%d+")*3600+60*X:match("%d+$")end
T=r(T)z={}y=0
for i=1,#l do
h=l[i]:match("%d.*")h=i>1 and y+h*60or r(h)y=h
z[#z+1]=h>T and l[i]:match("%u%l*")or nil
end return z end

retour = f({"Kevin 13:02","Ruby 5","Sam 3","Lisa 6","Bob 12"},"13:15")
for i=1,#retour
do
  print(retour[i])
end

2

Java, 346 304 284 275 байт

  • -9 байт, завдяки @KevinCruijssen
void g(int m,String[]n,String[]a,int M){for(int i=0;i<n.length;i++)if((M+=i>0?p(a[i]):0)>m)System.out.print(n[i]);}
int p(String n){return new Short(n);}
int h(String t){return p(t.split(":")[0])*60+p(t.split(":")[1]);}
void f(String[]n,String[]a,String b){g(h(b),n,a,h(a[0]));}

Детальний прямий ефір

public static void g(int m, String[] n, String[] a, int M)
{
    for(int i = 0; i < n.length; i++)
    {
        if((M += i>0 ? p(a[i]) : 0) > m)
        {
            System.out.println(n[i]);
        }
    } 
}

public static int p(String n)
{
    return Integer.parseInt(n);
}

public static int h(String t)
{
    return p(t.split(":")[0])*60+p(t.split(":")[1]);
}

public static void f(String[] n, String[] a, String b)
{
    g(h(b),n,a,h(a[0]));
}

1
Гарний гольф (для Java.) Вам потрібен пробіл між String[] n,і String[] a?
програміст5000

@ programmer5000 ні, я також видалив змінну годин і накопичив їх як хвилини.
Khaled.K

1
Ви можете замінити Integer.parseInt(n)на new Short(n). А виходячи з коментарів виклику, LisaBobтакож є дійсним результатом, тому ви можете змінити printlnна print.
Кевін Круїссен

1

Пакетна, 163 байти

@set/pp=
@set/ap=%p::=*60+%
:l
@set g=
@set/pg=
@if "%g%"=="" exit/b
@set t=%g:* =%
@set/ap-=%t::=*60+%
@for %%g in (%g%)do @(if %p% lss 0 echo %%g)&goto l

Бере вхід на STDIN. Перший рядок - час початку вечірки, потім список гостей. Використовує хитрість @ Арнаульда для перетворення hh: мм у хвилини.

Бажаним введенням для цього пакету буде як серія параметрів командного рядка (починаючи з часу партії, потім кожного гостя та часу як окремі аргументи). Це займе лише 129 байт:

@set p=%1
@set/ap=%p::=*60+%
:l
@set t=%3
@set/ap-=%t::=*60+%
@if %p% lss 0 echo %2
@shift
@shift
@if not "%2"=="" goto l


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