Перетворити введення в напрямок


15

Виклик

Задавши введення у формі, <n1>, <n2>де число може бути -1, 0 або 1, поверніть відповідний кардинальний напрямок . Позитивні числа переміщуються на схід по осі x, а південь на осі y, негативні числа - на захід по осі x і північ на осі y.

Вихід повинен бути в формі South East, North East, North. Це залежно від регістру.

Якщо вхід 0, 0, ваша програма повинна повернутися That goes nowhere, silly!.

Зразок вводу / виводу:

1, 1 -> South East

0, 1 -> South

1, -1 -> North East

0, 0 -> That goes nowhere, silly!

Це , найкоротша відповідь у байтах виграє.



1
Деякі приклади з W, NW та SW потрібні.
seshoumara

@seshoumara Я перебуваю на мобільному телефоні, тому жодних підстав, але NW буде -1, -1
Matias K

1
Чи дозволені проміжки простору?
Арджун

Ага ... Звичайно, я думаю. Поки це виглядає так само.
Matias K

Відповіді:


12

Japt , 55 51 байт

`
SÆ 
NÆ° `·gV +`
E†t
Wƒt`·gU ª`T•t goƒ Í2€e, Ðéy!

Пояснення

                      // Implicit: U, V = inputs
`\nSÆ \nNÆ° `       // Take the string "\nSouth \nNorth ".
·                     // Split it at newlines, giving ["", "South ", "North "].
gV                    // Get the item at index V. -1 corresponds to the last item.
+                     // Concatenate this with
`\nE†t\nWƒt`·gU       // the item at index U in ["", "East", "West"].
ª`T•t goƒ Í2€e, Ðéy!  // If the result is empty, instead take "That goes nowhere, silly!".
                      // Implicit: output result of last expression

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


Гм ... я ... ??? Як на землі це працює? Чи мають у Japt якісь химерні речі, які замінюють загальні пари персонажів?
HyperNeutrino

@HyperNeutrino Так, Japt використовує бібліотеку стиснення shoco, яка замінює загальні пари малих символів одним байтом.
ETHproductions

Гаразд, це справді круто! Я розберуся в цьому, побачу, чи зможу я скористатися цим.
HyperNeutrino

9

Пітон, 101 87 байт

Дійсно наївне рішення.

lambda x,y:['','South ','North '][y]+['','West','East'][x]or'That goes nowhere, silly!'

Дякуємо @Lynn за економію 14 байт! Зміни: Використання методу string.split фактично робить його довшим; _; А також негативні індекси існують у python.


5
Ви можете скоротити її до 87 так:lambda x,y:('','South ','North ')[y]+('','East','West')[x]or'That goes nowhere, silly!'
Лінн

2
Я знайшов акуратний спосіб отримати деякі вказівки, але, на жаль, не здається, що це спрацює для цього завдання. Зрозуміло, я б ділив його будь-коли (можливо, хтось хитріший, ніж я можу зрозуміти, як боротися з його проблемами, наприклад, коли x або y = 0): lambda x,y:'North htuoS'[::x][:6]+'EastseW'[::y][:4]Редагувати: це, ймовірно, буде занадто довго, але ви можете зробити друге нарізання [:6*x**2], так само і для рядка Схід / Захід, якщо ви можете обійти помилку на першій нарізці.
cole

@Lynn lambda x,y:('North ','South ')[y+1]+('West','East')[x+1]or'That goes nowhere, silly!'коротший на 2 байти
Dead Possum

@Lynn О, дякую! (Я забув про негативні показники!)
HyperNeutrino

@DeadPossum Це не працюватиме, оскільки повернеться South Eastза (0, 0). Дякую, хоча!
HyperNeutrino

6

PHP, 101 байт

[,$b,$a]=$argv;echo$a|$b?[North,"",South][1+$a]." ".[West,"",East][1+$b]:"That goes nowhere, silly!";

З давніх пір я програмував на PHP, але як він знає, Північ, Південь, Захід та Схід - це рядки без подвійних лапок навколо них? Це через порожню рядок, що розділяє той самий масив? Якщо так, чи це також означає, що ви не можете мати масив з різними типами одночасно (як масив як з рядком, так і з цілим числом)?
Kevin Cruijssen

1
@KevinCruijssen North є постійною php.net/manual/en/language.constants.php Якщо константа не існує, вона буде інтерпретуватися як рядок. Масив у PHP може містити різні типи. рядки можна вказати чотирма способами php.net/manual/en/language.types.string.php
Jörg Hülsermann

6

Perl 6 , 79 байт

{<<'' East South North West>>[$^y*2%5,$^x%5].trim||'That goes nowhere, silly!'}

Спробуй це

Розширено:

{ # bare block lambda with placeholder parameters 「$x」 and 「$y」

  << '' East South North West >>\ # list of 5 strings
  [                               # index into that with:

    # use a calculation so that the results only match on 0
    $^y * 2 % 5, # (-1,0,1) => (3,0,2) # second parameter
    $^x % 5      # (-1,0,1) => (4,0,1) # first parameter

  ]
  .trim  # turn that list into a space separated string implicitly
         # and remove leading and trailing whitespace

  ||     # if that string is empty, use this instead
  'That goes nowhere, silly!'
}

6

JavaScript (ES6), 106 100 97 93 байт

Це дуже простий підхід. Він складається з кількох потрійних операторів, вкладених разом -

f=a=>b=>a|b?(a?a>0?"South ":"North ":"")+(b?b>0?"East":"West":""):"That goes nowhere, silly!"

Випробування

f=a=>b=>a|b?(a?a>0?"South ":"North ":"")+(b?b>0?"East":"West":""):"That goes nowhere, silly!"

console.log(f(1729)(1458));
console.log(f(1729)(-1458));
console.log(f(-1729)(1458));
console.log(f(-1729)(-1458));
console.log(f(0)(1729));
console.log(f(0)(-1729));
console.log(f(1729)(0));
console.log(f(-1729)(0));


a!=0можна замінити просто a, оскільки 0 - хибний, а всі інші значення - неправдиві. Крім того, введення в синтаксис currying коротше, а також призначення масиву також коротше.
Лука

@Luke Дякую за пропозицію! Я відредагував відповідь. Тепер я б'ю рішення PHP та Python! Все через вас !!! Спасибі!
Арджун

Збережіть інший байт, виконуючи f=a=>b=>та викликаючи функцію типу f(1729)(1458); про currying syntaxщо згадував @Luke.
Том,

Ви можете сміливо використовувати a|bзамість a||b. Якщо припустити, що вхід складається лише з -1, 0 або 1 (що мені незрозуміло), ви можете замінити a>0і b>0на ~aі ~b.
Арнольд

Також вам не потрібні такі круглі дужки: a?(...):""/b?(...):""
Арнольд

4

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

@set s=
@for %%w in (North.%2 South.-%2 West.%1 East.-%1)do @if %%~xw==.-1 call set s=%%s%% %%~nw
@if "%s%"=="" set s= That goes nowhere, silly!
@echo%s%

forЦикл виступає в якості довідкової таблиці для фільтра , коли (можливо , зведені на немає) параметр дорівнює -1, і конкатенації подібні слова. Якщо нічого не вибрано, замість цього надрукується нерозумне повідомлення.


4

JavaScript (ES6), 86 байт

a=>b=>["North ","","South "][b+1]+["West","","East"][a+1]||"That goes nowhere, silly!"

Пояснення

Назвіть це за допомогою синтаксису currying ( f(a)(b)). Для цього використовуються індекси масиву. Якщо обоє aі bдорівнюють 0, результатом є помилковий порожній рядок. У цьому випадку рядок після ||повертається.

Спробуй це

Спробуйте всі тестові приклади тут:

let f=
a=>b=>["North ","","South "][b+1]+["West","","East"][a+1]||"That goes nowhere, silly!"

for (let i = -1; i < 2; i++) {
    for (let j = -1; j < 2; j++) {
        console.log(`${i}, ${j}: ${f(i)(j)}`);
    }
}


3

GNU sed , 100 + 1 (r прапор) = 101 байт

s:^-1:We:
s:^1:Ea:
s:-1:Nor:
s:1:Sou:
s:(.*),(.*):\2th \1st:
s:0...?::
/0/cThat goes nowhere, silly!

За задумом sed виконує скрипт стільки разів, скільки є рядків введення, тож можна виконати всі тестові випадки за один пробіг, якщо потрібно. Посилання TIO нижче робить саме це.

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

Пояснення:

s:^-1:We:                         # replace '-1' (n1) to 'We'
s:^1:Ea:                          # replace '1' (n1) to 'Ea'
s:-1:Nor:                         # replace '-1' (n2) to 'Nor'
s:1:Sou:                          # replace '1' (n2) to 'Sou'
s:(.*),(.*):\2th \1st:            # swap the two fields, add corresponding suffixes
s:0...?::                         # delete first field found that starts with '0'
/0/cThat goes nowhere, silly!     # if another field is found starting with '0',
                                  #print that text, delete pattern, end cycle now

Інший простір шаблону в кінці циклу друкується неявно.


2

05AB1E , 48 45 43 байт

õ'†Ô'…´)èUõ„ƒÞ „„¡ )èXJ™Dg_i“§µ—±æÙ,Ú¿!“'Tì

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

Пояснення

õ'†Ô'…´)                                       # push the list ['','east','west']
        èU                                     # index into this with first input
                                               # and store the result in X
          õ„ƒÞ „„¡ )                           # push the list ['','south ','north ']
                    èXJ                        # index into this with 2nd input
                                               # and join with the content of X
                       ™                       # convert to title-case
                        Dg_i                   # if the length is 0
                            “§µ—±æÙ,Ú¿!“       # push the string "hat goes nowhere, silly!"
                                        'Tì    # prepend "T"


2

Japt , 56 байт

N¬¥0?`T•t goƒ Í2€e, Ðéy!`:` SÆ NÆ°`¸gV +S+` E†t Wƒt`¸gU

Спробуйте в Інтернеті! | Тестовий сюїт

Пояснення:

N¬¥0?`Tt go Í2e, Ðéy!`:` SÆ NÆ°`¸gV +S+` Et Wt`¸gU
Implicit U = First input
         V = Second input

N´0?`...`:` ...`qS gV +S+` ...`qS gU
N¬                                                     Join the input (0,0 → "00")
  ¥0                                                   check if input is roughly equal to 0. In JS, "00" == 0
    ?                                                  If yes:
      ...                                               Output "That goes nowhere, silly!". This is a compressed string
     `   `                                              Backticks are used to decompress strings
          :                                            Else:
           ` ...`                                       " South North" compressed
                 qS                                     Split on " " (" South North" → ["","South","North"])
                   gV                                   Return the string at index V
                     +S+                                +" "+ 
                        ` ...`                          " East West" compressed
                              qS gU                     Split on spaces and yield string at index U

Підказка: 00це точно так же , як 0, як додаткова цифра стає видалена;)
ETHproductions

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

1

Сітківка , 84 82 81 байт

1 байт збережено завдяки @seshoumara за пропозицію 0...?замість0\w* ?

(.+) (.+)
$2th $1st
^-1
Nor
^1
Sou
-1
We
1
Ea
0...?

^$
That goes nowhere, silly!

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


Вихід неправильний. ОП хоче, щоб позитивні числа рухалися S по осі y, а від'ємні
seshoumara

@seshoumara правий, фіксований його ж ByteCount (тільки довелося свопу Norі Sou)
Kritixi Lithos

Добре. Крім того, ви можете голити 1 байт, використовуючи 0...?.
seshoumara

@seshoumara Спасибі за підказку :)
Kritixi Lithos

1

Швидкий 151 байт

func d(x:Int,y:Int){x==0&&y==0 ? print("That goes nowhere, silly!") : print((y<0 ? "North " : y>0 ? "South " : "")+(x<0 ? "West" : x>0 ? "East" : ""))}

1

PHP, 95 байт.

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

echo['North ','','South '][$argv[1]+1].[East,'',West][$argv[2]+1]?:'That goes nowhere, silly!';

Це покликане працювати з -rпрапором, отримуючи координаторів в якості 1-го та 2-го аргументів.


1

C # , 95 102 байти


Гольф

(a,b)=>(a|b)==0?"That goes nowhere, silly!":(b<0?"North ":b>0?"South ":"")+(a<0?"West":a>0?"East":"");

Безумовно

( a, b ) => ( a | b ) == 0
    ? "That goes nowhere, silly!"
    : ( b < 0 ? "North " : b > 0 ? "South " : "" ) +
      ( a < 0 ? "West" : a > 0 ? "East" : "" );

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

// A bitwise OR is perfomed
( a, b ) => ( a | b ) == 0

    // If the result is 0, then the 0,0 text is returned
    ? "That goes nowhere, silly!"

    // Otherwise, checks against 'a' and 'b' to decide the cardinal direction.
    : ( b < 0 ? "North " : b > 0 ? "South " : "" ) +
      ( a < 0 ? "West" : a > 0 ? "East" : "" );

Повний код

using System;

namespace Namespace {
    class Program {
        static void Main( string[] args ) {
            Func<Int32, Int32, String> f = ( a, b ) =>
                ( a | b ) == 0
                    ? "That goes nowhere, silly!"
                    : ( b < 0 ? "North " : b > 0 ? "South " : "" ) +
                      ( a < 0 ? "West" : a > 0 ? "East" : "" );

            for( Int32 a = -1; a <= 1; a++ ) {
                for( Int32 b = -1; b <= 1; b++ ) {
                    Console.WriteLine( $"{a}, {b} = {f( a, b )}" );
                }
            }

            Console.ReadLine();
        }
    }
}

Релізи

  • v1.1 - + 7 bytes- Згорнутий фрагмент у функцію.
  • v1.0 - 95 bytes - Початкове рішення.

Примітки

Я привид, бу!


1
Це фрагмент коду, вам потрібно перетворити його у функцію, тобто додати (a,b)=>{...}біт
TheLethalCoder

Ви можете використовувати currying, щоб зберегти байт a=>b=>, можливо, вам не знадобиться ()навколо a|b, ви можете використовувати інтерпольовані рядки, щоб і струна була добре
нарощена

Повністю забув перетворитись на функцію: S. Для ()навколо a|b, мені це потрібно, інакше Operator '|' cannot be applied to operands of type 'int' and 'bool'. Я також спробував інтерпольовані рядки, але не дав багато, хоча через ""помилки.
auhmaan

1

Скала, 107 байт

a=>b=>if((a|b)==0)"That goes nowhere, silly!"else Seq("North ","","South ")(b+1)+Seq("West","","East")(a+1)

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

Щоб скористатися цим, оголосіть це як функцію та зателефонуйте:

val f:(Int=>Int=>String)=...
println(f(0)(0))

Як це працює

a =>                                // create an lambda with a parameter a that returns
  b =>                              // a lambda with a parameter b
    if ( (a | b) == 0)                // if a and b are both 0
      "That goes nowhere, silly!"       // return this string
    else                              // else return
      Seq("North ","","South ")(b+1)    // index into this sequence
      +                                 // concat
      Seq("West","","East")(a+1)        // index into this sequence

1

C, 103 байти

f(a,b){printf("%s%s",b?b+1?"South ":"North ":"",a?a+1?"East":"West":b?"":"That goes nowhere, silly!");}

0

Java 7, 130 байт

String c(int x,int y){return x==0&y==0?"That goes nowhere, silly!":"North xxSouth ".split("x")[y+1]+"WestxxEast".split("x")[x+1];}

Пояснення:

String c(int x, int y){               // Method with x and y integer parameters and String return-type
  return x==0&y==0 ?                  //  If both x and y are 0:
     "That goes nowhere, silly!"      //   Return "That goes nowhere, silly!"
    :                                 //  Else:
     "North xxSouth ".split("x"[y+1]  //   Get index y+1 from array ["North ","","South "] (0-indexed)
     + "WestxxEast".split("x")[x+1];  //   Plus index x+1 from array ["West","","East"] (0-indexed)
}                                     // End of method

Код тесту:

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

class M{
  static String c(int x,int y){return x==0&y==0?"That goes nowhere, silly!":"North xxSouth ".split("x")[y+1]+"WestxxEast".split("x")[x+1];}

  public static void main(String[] a){
    System.out.println(c(1, 1));
    System.out.println(c(0, 1));
    System.out.println(c(1, -1));
    System.out.println(c(0, 0));
  }
}

Вихід:

South East
South 
North East
That goes nowhere, silly!

0

CJam , 68 байт

"
South 
North 

East
West"N/3/l~W%.=s_Q"That goes nowhere, silly!"?

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

Друкує один пробіл на [0 -1]або [0 1]( Northабо South).

Пояснення

"\nSouth \nNorth \n\nEast\nWest"  e# Push this string
N/                                e# Split it by newlines
3/                                e# Split the result into 3-length subarrays,
                                  e#  gives [["" "South " "North "]["" "East" "West"]]
l~                                e# Read and eval a line of input
W%                                e# Reverse the co-ordinates
.=                                e# Vectorized get-element-at-index: accesses the element
                                  e#  from the first array at the index given by the 
                                  e#  y co-ordinate. Arrays are modular, so -1 is the last
                                  e#  element. Does the same with x on the other array.
s                                 e# Cast to string (joins the array with no separator)
_                                 e# Duplicate the string
Q"That goes nowhere, silly!"?     e# If it's non-empty, push an empty string. If its empty, 
                                  e#  push "That goes nowhere, silly!"

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