Нещодавно знайдене число: bleen!


44

"Нобелівська премія з математики була присуджена каліфорнійському професору, який виявив нове число! Це число замішане, яке, на його думку, належить між 6 і 7." - Джордж Карлін

У цьому виклику ви будете друкувати всі цілі числа, включно, у межах заданого діапазону введення. Друкуйте числа, що збільшуються або зменшуються відповідно до їх порядку введення. Тобто для введення [n1, n2], друкуйте по зростаючому, якщо n1 < n2, за убуванням, якщо n1 > n2.

Оскільки bleenзараз це число Integer, воно може бути використане як вхідне. Він також повинен бути включений у висновок, між 6та 7де це можливо. Також зауважте, що -bleenіснує між -7 і -6.

Вхідні дані

Два цілих [n1, n2]числа в діапазоні [-10, 10], включно, через вхід вашої мови програмування.

(Введення також може містити bleenі -bleen!)

Вихід

Роздрукуйте всі цілі особи, починаючи з n1і закінчуючи n2, включаючи нещодавно виявлені bleenміж 6 і 7. Вихідним сигналом може бути діапазон символів, розділених символами, у певній формі, яку підтримує ваша мова - тобто розділені комою або пробілом. Одне кінцевий простір виводу добре.

Приклади

Input:  1 10
Output: 1 2 3 4 5 6 bleen 7 8 9 10 

Input:  -9 -4
Output: -9 -8 -7 -bleen -6 -5 -4

Input:  -8 bleen
Output: -8 -7 -bleen -6 -5 -4 -3 -2 -1 0 1 2 3 4 5 6 bleen

Input:  9 1
Output: 9 8 7 bleen 6 5 4 3 2 1

Input:  2 -bleen
Output: 2 1 0 -1 -2 -3 -4 -5 -6 -bleen

Input:  -bleen 0
Output: -bleen -6 -5 -4 -3 -2 -1 0

Input:  bleen bleen
Output: bleen

Input:  2 2
Output: 2

Додаткові нотатки

Ви можете написати програму або функцію та використовувати будь-який стандартний метод отримання вводу та надання виводу.

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

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


16
Чи є також bleenteen між 16 і 17? (а чи є бленден-бленд між бленден-шістьма та бленті-сім?)
Йофан

5
@Joffan ... і блеенти між 60 і 70?
Адам

5
@Joffan Скільки коштує (bleen + 7) / 2?
Адам

10
У математиці є лише медаль Поля, там немає Нобелівських призів ....
Грайфер

8
@Graipher Тому не варто покладатися на репутацію коміка як на важку новину;)
Geobits

Відповіді:


12

Python 3, 132 130 байт

r=round
bleen=6.1
m=1.08
a,b=eval(input())
d=1-2*(a>b)
print(*[[r(i/m),"-bleen"[i>0:]][i*i==49]for i in range(r(m*a),d+r(m*b),d)])

Вводиться в такому прикладі:

-8, bleen

Це працює за межами [-10,10]?
mbomb007

@ mbomb007 Ні.
orlp

Дуже геніальне рішення з bleen та eval там, приємне. Ще одна пропозиція: використовувати bleen=7/mдля очищення без покарання персонажів
WorldSEnder

@orlp Чи є причина, що ви назвали змінну bleen, а не просто однозначну таблицю?
Блакитний

@muddyfish Так, це потрібно, evalщоб перевести bleenу правильне значення.
orlp

9

Рубі, 114 100 98 байт

Вхід - це масив з [n1, n2]. (Якщо має бути два окремих аргументу, +1 байт, щоб змінити аргумент функції з gна *g. Bleen повинен бути рядок "bleen". але я також гольфував ще 7 після цього.

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

->g{a=*-10..-7,?-+b='bleen',*-6..6,b,*7..10;x,y=g.map{|v|a.index v}
y<x ?a[y..x].reverse: a[x..y]}

Оригінальна повна версія програми, яка читає вхід з ARGV:

b='bleen'
a=[*-10..-7,?-+b,*-6..6,b,*7..10].map &:to_s
x,y=$*.map{|v|a.index v}
puts y<x ?a[y..x].reverse: a[x..y]

Якщо ви зробите це лямбда, ви можете позбутися .map &:to_sта зберегти 6 байт, а ще один зберегти, змінивши ініціалізацію aна a=*-10..10;a[4,0]=?-+b;a[18,0]=b.
Йорданія

Тобто->*g{b='bleen';a=*-10..10;a[4,0]=?-+b;a[18,0]=b;x,y=g.map{|v|a.index v};puts y<x ?a[y..x].reverse: a[x..y]}
Йорданія

@Jordan спасибі Не потрібно було використовувати трюк нарізки, щоб вставити блен; мій склад масиву ще коротший приблизно на 1 байт.
Значення чорнила

Ах, я рахував дужки; забув, ти можеш їх опустити.
Йорданія

Я повинен підняти або залишити вас рівно в 4 к?
NoOneIsHere

8

Pyth , 35 байт

K++L\-P_J++`M7"bleen"`M}7TJ@LK}FxLK

Тестовий набір.

Перша частина, тобто K++L\-P_J++`M7"bleen"`M}7TJгенерує цей масив:

['-10', '-9', '-8', '-7', '-bleen', '-6', '-5', '-4', '-3', '-2', '-1', '0', '1', '2', '3', '4', '5', '6', 'bleen', '7', '8', '9', '10']

а потім зберігає його в K.

Друга частина, тобто @LK}FxLKзнаходить підпис, вказаний вводом.


1
Я думав і про такий підхід. Безумовно, цікаво, якщо нам довелося взяти будь-який діапазон int ...
Adám

... і особливо, якщо нам довелося включати блентейн і блендети тощо.
Адам

8

Пітон 3, 157 145 123 108 115 139 161 158 153 байт

Збережено 22 завдяки Лінні. 17 врятовано завдяки shooqie. 3 збережено завдяки ljeabmreosn. 5 врятованих завдяки Джеффу Риді.

a,b=eval(input())
s='-'
c='bleen'
d=a<b
l=list(map(str,range(-10,11)))[::[-1,1][d]]
x=l.insert
y=l.index
x(4,d*s+c)
x(18,(1^d)*s+c)
print(l[y(a):y(b)+1])

Вхід як '-10', '8'. Поради вітаються для початківця.

До облікового запису додано 7 -bleen. Додано 15 до облікового запису для зворотного введення '8','-10'. Додано велику 21 за рахунком для обернено введення знаків bleenпроти -bleen.


2
l.index('-6')і l.index('7')повинні бути просто константами, ні?
Лінн

2
l=[str(i)for i in range(-10,11)]->l=list(map(str,range(-10,11)))
shooqie

2
Хоча я не впевнений, навіщо вам потрібні рядки в першу чергу. l=list(range(-10,11))працює також
shooqie

2
Рядки 2, 4, 5 можна замінити на for i in(4,18):l.insert(i,'bleen').
shooqie

1
@shooqie У циклі for for відсутній негативний знак в індексі 4. Наприклад, у списку є два елементи, 'bleen'а не'-bleen','bleen'
Justin

3

Рубін, 141 байт

->*a{
l="bleen"
s=13
a,b=a.map{|n|2*n rescue s*(n<=>?b)}
b,a,r=a,b,1if b<a
o=(a..b).map{|n|n==s ?l:n==-s ??-+l:n/2}.uniq
puts r ?o.reverse: o}

Безумовно

lambda do |*args|
  bleen = "bleen"
  subst = 13 # This will stand in for "bleen"

  a, b = args.map {|arg|
    begin
      # Double the number
      2 * arg
    rescue
      # It wasn't a number, so it's "bleen" or "-bleen"; replace it with 13 or -13
      subst * (arg <=> "b")
    end
  }

  if b < a
    # If the range isn't ascending, reverse it and remember that we did
    b, a, reverse = a, b, 1
  end

  # Step through the range, replacing 13 and -13 with "bleen" and "-bleen" and
  # halving everything else
  result = (a..b).map {|n|
    if n == subst
      bleen
    elsif n == -subst
      "-" + bleen
    else
      n / 2
    end
  }.uniq # Drop duplicates

  # Reverse the result if the range was descending
  puts reverse ? result.reverse : result
end

3

Пакетна, 239 186 байт

@set/ableen=1431655772,a=%1*3,b=%2*3,c=b-a^>^>31^|1
@for /l %%i in (%a%,%c%,%b%)do @((if %%i==20 echo bleen)&(if %%i==-20 echo -bleen)&set/aj=%%i%%3,k=%%i/3&cmd/cif %%j%%==0 echo %%k%%)

Працює шляхом циклічного перегляду 3*%1на, 3*%3а потім ділення на три та друкування чисел без залишку, проте встановлення bleenна це магічне число викликає переповнення цілого числа, а 20замість цього використовується значення . Потім він роздруковується у відповідній точці циклу.


@ edc65 Коли я востаннє прочитав запитання правильно вперше ...
Ніл

@ edc65 о, і я -bleenтеж забув . Ба.
Ніл

Спробував це, але результатів немає. Приклад використання?
edc65

@ edc65 bleen.bat bleen -bleenможливо?
Ніл

Як я вже сказав, немає виходу. Це дос / windows bat мова? Я використовую Windows 10
edc65

3

JavaScript (ES6), 158

Гарний виклик, важкий для гольфу. Можливо, методи діапазону, які використовуються у відповідях Python та Ruby, могли б отримати кращий результат навіть у JS.

(a,b)=>(c=x=>x<-6?x-1:x>6?x+1:1/x?x:x<'b'?-7:7,a=c(a),b=c(b),d=b>a?1:-1,a-=d,e=x=>x-7?x-(x>7):'bleen',[...Array(d*(b-a))].map((x=a+=d)=>x<0?'-'+e(-x):e(x)))  

Менше гольфу

(a,b)=>(
  c=x=>x<-6?x-1:x>6?x+1:1/x?x:x<'b'?-7:7,
  a=c(a),b=c(b),
  d=b>a?1:-1,
  a-=d,
  e=x=>x-7?x-(x>7):'bleen',
  [...Array(d*(b-a))].map((x=a+=d)=>x<0?'-'+e(-x):e(x))
)  

Тест

f=(a,b)=>(c=x=>x<-6?x-1:x>6?x+1:1/x?x:x<'b'?-7:7,a=c(a),b=c(b),d=b>a?1:-1,a-=d,e=x=>x-7?x-(x>7):'bleen',[...Array(d*(b-a))].map((x=a+=d)=>x<0?'-'+e(-x):e(x)))  

function go(){
  var a=A.value,b=B.value
  // make them numeric if possible
  a=isNaN(a)?a:+a
  b=isNaN(b)?b:+b
  
  O.textContent=f(a,b)
}  
go()
A <select id=A onchange='go()'>
<option>-10<option>-9<option>-8<option>-7<option>-bleen<option>-6<option>-5<option>-4<option>-3<option>-2<option>-1<option>0
<option>1<option>2<option>3<option>4<option>5<option>6<option>bleen<option>7<option>8<option>9<option>10
</select>
B <select id=B onchange='go()'>
<option>-10<option>-9<option>-8<option>-7<option>-bleen<option>-6<option>-5<option>-4<option>-3<option>-2<option>-1<option>0
<option>1<option>2<option>3<option>4<option>5<option>6<option>bleen<option>7<option>8<option>9<option selected>10
</select>
<pre id=O></pre>


Я думаю, ти пропустив -6.
betseg

3

Швидкий 2.2, 342 байт

func a(x:String,y:String){var k="bleen",a=Int(x) ?? (x==k ?(x==y ? -9:6):-6),b=Int(y) ?? (y==k ?6:-6),t=0,s=[Any](),f=Int(x)==nil ?x:"";if a>b{t=a;a=b;b=t};for i in a...b{if i==7 && a != 7{s.append(k)};s.append(i);if -i==7 && b != -7{s.append("-"+k)}};for v in t==0 ?s:s.reverse(){f+=" \(v)"};if Int(y)==nil&&b>0{f+=" \(y)"};print(x==y ?x:f)}

Перевірте це за допомогою Swift Sandbox від IBM

Безумовно

func bleen(x: String, y: String){
    var k = "bleen",
        a = Int(x) ?? (x == k ? (x == y ? -9 : 6) : -6),
        b = Int(y) ?? (y == k ? 6: -6),
        t = 0,
        s = [Any](),
        f = Int(x) == nil ? x : ""

    if a > b{
        t = a
        a = b
        b = t
    }

    for i in a...b{
        if i == 7 && a != 7{s.append(k)}
        s.append(i)
        if -i == 7 && b != -7{s.append("-" + k)}
    }

    if Int(y) == nil && b > 0{s.append(y)}

    for v in t == 0 ? s : s.reverse(){
        f+="\(v) "
    }

    print(x == y ? x : f)
}

2

Java, 271 байт

int p(String w){if(w.contains("b"))return w.length()<6?7:-7;int i=Integer.decode(w);return i<-6?i-1:i>6?i+1:i;}void b(String s,String f){Integer l=p(s),r=p(f);for(r+=l<r?1:-1;l!=r;l-=l.compareTo(r))System.out.print(l==-7?"-bleen ":l==7?"bleen ":l+(l<-7?1:l<7?0:-1)+" ");}

Недоліковані з тестовими кейсами:

class Bleen {
     static int p(String w) {
         if(w.contains("b"))
             return w.length() < 6 ? 7 : -7;
         int i = Integer.decode(w);
         return i < -6 ? i-1 : i>6 ? i+1 : i;
     }

     static void b(String s, String f) {
         Integer l = p(s), r = p(f);
         for(r += l<r ? 1 : -1; l != r; l -= l.compareTo(r))
             System.out.print(l == -7 ? "-bleen " : l == 7 ? "bleen ": l+(l < -7 ? 1 : l<7 ? 0 : -1)+" ");
     }

     public static void main(String[] args) {
         b("1","10"); System.out.println();
         b("-9","-4"); System.out.println();
         b("-8", "bleen"); System.out.println();
         b("9", "1"); System.out.println();
         b("2", "-bleen"); System.out.println();
         b("-bleen", "0"); System.out.println();
         b("bleen", "bleen"); System.out.println();
         b("2", "2"); System.out.println();
     }
}

Дзвінок b (початок, кінець). Оскільки параметри - це рядки, для перетворення їх у ints потрібно багато місця. По суті, програма розглядає 7 & -7 як блеен і -білен.


1
Приємна відповідь, +1. Було досить важко придумати щось для гольфу, який ви відповідаєте, але я це зробив. ;) Ваш метод pможе бути змінений на наступний , щоб зберегти 6 байт: int p(String w){int x=w.length(),i;if(x>3)return x<6?7:-7;i=Integer.decode(w);return i<-6?i-1:i>6?i+1:i;}. Крім того, ви можете сказати, що це Java 7 і, можливо, додати ідеону .
Kevin Cruijssen

Крім того, мені вдалося зробити коротший варіант в Java 7 на основі підходу @LeakyNun до створення першого списку.
Kevin Cruijssen

2

Java 7, 251 байт

import java.util.*;String b(Object...a){String q="bleen",r="";List l=new ArrayList();int j=-10,i,z,y,t;while(j<11)l.add(j++);l.add(4,"-"+q);l.add(18,q);z=l.indexOf(a[0]);y=l.indexOf(b[1]);if(y<z){t=z;z=y;y=t;}for(i=z;i<=y;)r+=l.get(i++)+" ";return r;}

Інший підхід, який коротший, ніж у вже наявної відповіді на Java 7 .
Крім того, прикро, що параметри потенційно не в порядку, що додає кілька байтів, щоб поміняти їх навколо.

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

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

import java.util.*;
class Main{
  static String b(Object... a){
    String q = "bleen",
           r = "";
    List l = new ArrayList();
    int j = -10, i, z, y, t;
    while(j < 11){
      l.add(j++);
    }
    l.add(4, "-"+q);
    l.add(18, q);
    z = l.indexOf(a[0]);
    y = l.indexOf(a[1]);
    if(y < z){
      t = z;
      z = y;
      y = t;
    }
    for(i = z; i <= y; ){
      r += l.get(i++) + " ";
    }
    return r;
  }

  public static void main(String[] a){
    System.out.println(b(1, 10));
    System.out.println(b(-9, -4));
    System.out.println(b(-8, "bleen"));
    System.out.println(b(9, 1));
    System.out.println(b(2, "-bleen"));
    System.out.println(b("-bleen", 0));
    System.out.println(b("bleen", "bleen"));
    System.out.println(b(2, 2));
  }
}

Вихід:

1 2 3 4 5 6 bleen 7 8 9 10 
-9 -8 -7 -bleen -6 -5 -4 
-8 -7 -bleen -6 -5 -4 -3 -2 -1 0 1 2 3 4 5 6 bleen 
1 2 3 4 5 6 bleen 7 8 9 
-bleen -6 -5 -4 -3 -2 -1 0 1 2 
-bleen -6 -5 -4 -3 -2 -1 0 
bleen 
2 

2

Scala, 223 байт

object B extends App{val b="bleen"
val L=((-10 to -7)++List(s"-$b")++(-6 to 6)++List(b)++(6 to 10)).map(""+_)
val Array(s,e)=args.map(L.indexOf(_))
println((if(s<=e)L.slice(s,e+1)else L.slice(e,s+1).reverse).mkString(" "))}

2

JavaScript (ES6), 178 байт

 (s,e)=>{q='bleen';t=[];for(i=-10;i<11;i++)t.push(i);t.splice(4,0,'-'+q);t.splice(18,0,q);s=t.indexOf(s);e=t.indexOf(e);s>e&&t.reverse()&&(e=22-e)&&(s=22-s);return t.slice(s,e+1)}

Спробуй це

EDIT: Виправлення зворотного замовлення. Дякую Патріку, цю умову пропустили


2

Python 3, 126 байт

Введіть форму -5, 'bleen'

l=list(range(-10,11))
c='bleen'
s=l.insert
t=l.index
s(4,'-'+c)
s(18,c)
i,j=map(t,eval(input()))
d=1-2*(i<j)
print(l[i:j+d:d])

2

R , 110 107 байт

Завдяки Cyoce за гольф у 3 байти.

a=function(x,y){e=c(-10:-7,"-bleen",-6:6,"bleen",6:10)
b=function(d)which(e==as.character(d))
e[b(x):b(y)]}

Будує весь список по порядку, підбирає відповідні. Функція в середині з назвою "b" здавалася найпростішим способом зробити це. Застосовувати тощо


Чи потрібно все, що пробіл?
Cyoce

Ні, і зазвичай у мене цього не було б. Дякую! Редагувати: Я навіть багато не рахував. Повинно було заснути.
користувач5957401

1

Javascript (за допомогою зовнішньої бібліотеки) (343 байти)

(a,b)=>{r="bleen";s="-"+r;c=d=>d==r?7:(d==s?-7:d);i=c(a);j=c(b);m=Math.min(i,j);n=Math.max(i,j);w=i<=j?_.RangeTo(i,j):_.RangeDown(i,Math.abs(j-i)+1);g=i<j?6:7;if(n>-7&&m<-6){w=w.InsertWhere("-bleen",x=>x==-7)}if(m<8&&n>6){w=w.InsertWhere("bleen",x=>x==g)}if(a==r||b==r){w=w.Where(x=>x!=7)}if(a==s||b==s){w=w.Where(x=>x!=-7)}return w.ToArray()}

Посилання на lib: https://github.com/mvegh1/Eumerable

Знімок екрана:

введіть тут опис зображення


-1

Python 2, 100 байт

Перші чотири рядки генерують список [-10, -9, -8, -7, 'bleen', -6, -5, -4, -3, -2, -1, 0, 1, 2, 3, 4, 5, 6, 'bleen', 7, 8, 9, 10]. Наступний рядок отримує вхід і зберігає його у sта e. Останні два рядки використовують .index()і списують позначення нарізки, щоб отримати правильний діапазон.

a=range(-10,11)
b="bleen"
c=a.insert
c(17,b)
c(4,b)
s,e=eval(input())
d=a.index
print a[d(s):d(e)+1]

Працює так само, як відповідь Лікі Нун, але розвивався самостійно. Вкрасти метод введення від orlp.

Безголівки:

array = range(-10, 11)
array.insert(17, "bleen")
array.insert(4, "bleen")
start, end = eval(input())
print array[array.index(start):array.index(end) + 1]

Це неправильно - число між -7і -6є -bleen, ні bleen. Хоча ми знайшли нове число, основні правила алгебри повинні залишатися незмінними: 0це єдине число, яке є власною додатковою оберненою силою, в силу того, що є елементом ідентичності добавки. Крім того, eval(input())якраз input()у Python 2.
Mego

@Mego oh, oops ....
noɥʇʎԀʎzɐɹƆ
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.