1 + 1 = 10, 1 + 2 = 3


26

आधार 10 और आधार 2 दोनों में साधारण अंकगणित (जोड़, घटाव, गुणा और भाग) कर सकते हैं, से एक फ़ंक्शन या प्रोग्राम लिखें।

फ़ंक्शन इनपुट के रूप में गणितीय अभिव्यक्ति लेगा, और सही आधार में सही परिणाम का उत्पादन करेगा। इनपुट nएक या कई ऑपरेटरों द्वारा अलग किए गए नंबर होंगे ( + - * /)।

यदि सभी इनपुट मानों में केवल 0 और 1 होते हैं, तो सभी मानों को बाइनरी माना जाता है। यदि कम से कम एक अंक है 2-9, तो सभी मानों को आधार 10 माना जाता है।

नियम:

  • आप मान सकते हैं कि संख्याओं के बीच केवल एक ऑपरेटर 10*-1होगा ( दिखाई नहीं देगा)
  • आप मान सकते हैं कि कोई कोष्ठक नहीं होगा।
  • सामान्य ऑपरेटर पूर्वता (यदि आप संदेह में हैं तो Google कैलकुलेटर में अभिव्यक्ति का प्रयास करें)।
  • आप यह नहीं मान सकते कि केवल पूर्णांक होंगे
  • इनपुट या आउटपुट में कोई अग्रणी शून्य नहीं होगा
  • आप मान सकते हैं कि केवल वैध इनपुट दिया जाएगा
  • आप मान सकते हैं कि सभी इनपुट वैल्यू पॉजिटिव हैं (लेकिन माइनस ऑपरेटर नकारात्मक आउटपुट को संभव बना सकता है, 1-2=-1और 10-100=-10)
  • REPL स्वीकार नहीं किया जाता है
  • आप इनपुट लेने के लिए अलग तर्क के रूप में, या एक ही तर्क के रूप में चुन सकते हैं, लेकिन इनपुट है सही क्रम में किया जाना है।
    • यानी आप का प्रतिनिधित्व कर सकते 1-2इनपुट तर्क के साथ 1, -, 2, लेकिन नहीं 1, 2, -
  • आपको + - * /इनपुट आदि में प्रतीकों को स्वीकार करना चाहिए plus, minusआदि।
  • आपको फ़्लोटिंग पॉइंट वैल्यू (या अपनी भाषा की अधिकतम सीमा तक) का समर्थन करना चाहिए, हालाँकि केवल पूर्णांकों का समर्थन स्वीकार नहीं किया जाता है।
  • eval स्वीकार कर लिया है

उदाहरण:

1+1
10

1010+10-1
1011

102+10-1
111

1+2+3
6

10*10*10
1000

11*11*11
11011

10*11*12+1
1321

10.1*10.1
110.01

20.2*20.2
408.04

10/5
2

110/10
11

Also accepted (optional line or comma-separated input):
10
+
10
-
1
11    <-- This is the output

यह कोड गोल्फ है, इसलिए बाइट्स में सबसे छोटा कोड जीत जाएगा।


के मामले में 110/10, है 11.0स्वीकार्य?
इसहाक

@isaacg हाँ, यह ठीक है :-)
स्टीवी ग्रिफ़िन 15

5
चढ़ाव ... क्यों?
स्टीवी ग्रिफिन

जवाबों:


5

जाप, 77 72 62 60 62 * 60 59 51 बाइट्स

OvUf"[2-9]" ?U:"({Ur"[\\d.]+""º$&e14+P n2 /2pE¹"})¤

स्पष्टीकरण (जेएस के उत्तर के लिए कमोबेश वही):

Ov                       //eval...
  Uf"[2-9]"              //if input contains the digits 2 to 9
    U:                   //then it's base 10, just compute
    Ur"[\\d.]+"          //otherwise replace all the numbers
    "º$&e14+P n2 /2pE¹"  //with their base 10 equivalents
                         //I.e., take every number, multiple by 10^14, convert to
                         //base 10 and divide by 2^14
                         // º and ¹ are multiple brackets
    ¤                    //means "s2", i.e. convert the result to binary

इसे ऑनलाइन आज़माएं!


* ठीक से विभाजित नहीं किया


के रूप में 5 दिन पहले , जे एस के evalलिए असाइन किया गया है Ox। मैं देखूंगा कि क्या इसे और छोटा किया जा सकता है।
ETHproductions

@ धन्यवाद, यह 5 बाइट्स बचाता है।
निकेल

5 और बाइट्स बचाए गए: OxUf"[2-9]" ?U:`({Ur"\\d+(\\.\\d+)?""(($&e14+P).n(2)/16384)"}).s(2)जेएस के बजाय इसे जप्ट कोड बनाना संभव है, फिर इसका Ovमूल्यांकन करने के लिए उपयोग करें।
ETHproductions

यूप, 62 बाइट्स :) OvUf"[2-9]" ?U:Ur"\\d+(\\.\\d+)?""~~[$&e14+P n2 /16384]" +" s2यह ~~[...]आवश्यक है क्योंकि ट्रांसपॉइलर के साथ एक स्ट्रिंग गड़बड़ में बेमेल कोष्ठक
16

1
51:OvUf"[2-9]" ?U:"({Ur"[\\d.]+""º$&e14+P n2 /2pE¹"})¤
ETHproductions

9

जावास्क्रिप्ट ईएस 6, 87 97 1 100 2 106 3 102 101 98 100 4 93 88 86 बाइट्स

e=>eval(e.match`[2-9]`?e:`(${e.replace(/[\d.]+/g,"('0b'+$&e14)/16384")}).toString(2)`)

डेमो + स्पष्टीकरण:

function c(e){
    return eval(                        
      e.match`[2-9]`?                  //check if there are numbers 2 to 9
        e:                             //if there're, just compute the result
        "("+                           
         e.replace(                    //otherwise replace...
           /[\d.]+/g,                  //any number...
           "(('0b'+$&e14)/16384)"    //...with itself converted to base 10
         )
        +").toString(2)"               //compute the result and convert it to binary
    )
}

document.write(
   c("1.1*1.1")+"<br>"+
   c("1010+10-1")+"<br>"+
   c("102+10-1")+"<br>"+
   c("1+2+3")+"<br>"+
   c("10*10*10")+"<br>"+
   c("11*11*11")+"<br>"+
   c("10*11*12+1")+"<br>"+
   c("10.1*10.1")+"<br>"+
   c("20.2*20.2")+"<br>"+
   c("10/5")+"<br>"+
   c(`10
      +
      10
      -
      1`)
)


1 - फ़्लोट्स के बारे में भूल गया
2 - फिर से तैरने की समस्या: पार्सइंट फर्श बाइनरी इसलिए मुझे 1e14 से गुणा करना होगा और फिर 16384
3 से विभाजित करना होगा - आशा है कि दिए गए कार्य को प्राप्त किया है, अब गोल्फ शुरू करें: डी
4 - विभाजन के साथ एक बग था


10
106 ^ 3 बाइट्स? यह एक मिलियन से अधिक है!
ETHproductions

2
@ मुझे पता था कि ऐसी टिप्पणी आ रही है; डी
निकेल

आप बदल सकते हैं e.match(/[2-9]/g)करने के लिए e.match`[2-9]`
15:81 पर user81655

@user धन्यवाद :)
nicael

@nicael ('0b'+$&*1e14)/1638यह काम करना चाहिए, लेकिन मुझे यकीन नहीं है कि 100%
डाउनागोट

5

जोल्फ, 31 बाइट्स, नॉनकमेटिंग

मैंने इस चुनौती से प्रेरित कार्यों की एक अच्छी मात्रा को जोड़ा, और, इस प्रकार, इसे गैर-जटिल माना जाता है। मैं खुश हूं क्योंकि मैंने आखिरकार यूनिरी फ़ंक्शंस लागू किए (जैसे (H,S,n)=>valES6 में, लेकिन ES5 में समर्थित हैं!)

? hi"[2-9]"~eiB~epT mpvid|m'H2H
? hi"[2-9]"                     if the input contains any of 2..9
           ~ei                   evaluate i (implicitly print)
                                else
                   _mpvid        map the input split into number groups
                          m'H2    to H as a binary float
                         |    H   (or keep H, if that doesn't work)
                 pT              join by spaces
               ~e                evaluate
              B                  convert to binary (implicitly print)

टेस्ट सूट , अपने स्वयं के इनपुट का प्रयास करें , या मैन्युअल रूप से इनपुट सेट करें


4
आपका कोड अपने पाठकों को "हाय" कहता है!
साइओस

वाह। मैंने देखा कि नहीं! : D
कॉनर ओ'ब्रायन

5

बैश, 60 बाइट्स

[ -z `tr -dc 2-9<<<$1` ]&&s='obase=2;ibase=2;';bc -l<<<$s$1

उदाहरण रन:

$ ./bin_dec_add.sh 1+1
10
$ ./bin_dec_add.sh 1+2
3

@ Pietu1998 dcको संचालन के रिवर्स पॉलिश ऑर्डरिंग की आवश्यकता होगी, जो चुनौती से अस्वीकृत है।
टाइजॉइड 15

3

𝔼𝕊𝕄𝕚𝕟 2, 46 चार्ट / 72 बाइट्स

ë(ïđ/[2-9]⎞?ï:`(⦃ïē/[\d.]+⌿,↪(Յ+$*ḊⁿḎ)/Ẁ²)})ⓑ`

Try it here (Firefox only).

व्याख्या

ë(ïđ/[2-9]⎞?ï:`(⦃ïē/[\d.]+⌿,↪(Յ+$*ḊⁿḎ)/Ẁ²)})ⓑ` // implicit: ï=input, Ḋ=10, Ḏ=14, Ẁ=128
ë(                                              // eval
  ïđ/[2-9]⎞?                                    // does ï have 2-9?
            ï                                   // if so, eval input
             :                                  // else, eval:
              `(⦃ïē/[\d.]+⌿,                    // replace the binary numbers
                                                // with their base 10 equivalents:
                            ↪(Յ+                // translates to `0b`
                                $*ḊⁿḎ           // matched number * 10^14
                                     )/Ẁ²       // divided by 128^2
                                         )})ⓑ` // converted to binary
                                                // implicit output

1

पॉवरशेल, 107 बाइट्स

param($e)iex(("{0}String($($e-replace'(\d+)','{0}Int32("$1",2)'),2)"-f'[Convert]::To'),$e)[$e-match'[2-9]']

Ungolfed

param($e) # Accept single argument
Invoke-Expression # Eval
  ( # Expression, resulting in an array of 2 elements
    (
      "{0}String( # Binary
        $( # Inline subexpression
          $e -replace'(\d+)', '{0}Int32("$1",2)'
          # "1010+10-1" becomes "{0}Int32("1010",2)+{0}Int32("10",2)-{0}Int32("1",2)"
        )
      ,2)"
      -f '[Convert]::To'
      # "{0}Int32("1010",2)+{0}Int32("10",2)-{0}Int32("1",2)" becomes
        "[Convert]::ToString([Convert]::ToInt32("1010",2)+[Convert]::ToInt32("10",2)-[Convert]::ToInt32("1",2),2)"
    ),
      $e # Plain
    )
    [$e-match'[2-9]'] # Return 1st element of array if regex matches, else 0

उदाहरण

PS > .\Calc.ps1 1010+10-1
1011

PS > .\Calc.ps1 20.2*20.2
408,04
हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.