ลบอัตราต่อรองของฉันจากเหตุการณ์ของฉัน


19

รับค่าเป็นจำนวนเต็มที่ไม่เป็นลบคืนค่าความต่างสัมบูรณ์ระหว่างผลรวมของเลขคู่และผลรวมของเลขคี่

กฎเริ่มต้น

  • มีช่องโหว่มาตรฐาน

  • คุณสามารถรับอินพุตและให้เอาต์พุตโดยวิธีอินพุต / เอาต์พุตมาตรฐานใด ๆ

  • คุณอาจรับอินพุตเป็นสตริงในฐานะจำนวนเต็มหรือเป็นรายการตัวเลข

  • นี่คือดังนั้นโค้ดที่สั้นที่สุดเป็นไบต์ในทุกภาษาชนะ!

กรณีทดสอบ

อินพุต ~> เอาท์พุท

0 ~> 0 (| 0-0 | = 0)
1 ~> 1 (| 1-0 | = 1)
12 ~> 1 (| 2-1 | = 1)
333 ~> 9 (| 0- (3 + 3 + 3) | = 9)
459 ~> 10 (| 4- (5 + 9) | = 10)
2469 ~> 3 (| (2 + 4 + 6) -9 | = 3)
1234 ~> 2 (| (2 + 4) - (1 + 3) | = 2)

1
ขอให้เราป้อนข้อมูลเป็นรายการของ ints ได้ไหม
อดัม

4
@ Mr.Xcoder นั่นคงไม่สำคัญอะไรเกินไป มันทำให้ความท้าทายมีความซับซ้อนเกินความจำเป็นและเป็นความต้องการโดยพลการที่เพิ่มไบต์
Okx

4
@ Mr.Xcoder อย่าทำให้ความท้าทายกิ้งก่า ประโยคที่สำคัญที่สุดที่คุณอาจต้องการดูที่นี่คือการรวมความท้าทายหลักที่ไม่เกี่ยวข้องสองรายการเข้าด้วยกัน - พิจารณาแยกความท้าทายออกเป็นความท้าทายที่แยกจากกันหรือแยกส่วนที่ไม่จำเป็นออก
Okx

1
* chamel e on challenge
เครื่องคิดเลข

1
ฉันเปลี่ยนกฎ @Okx แล้ว การเป็นรายการของตัวเลขได้รับอนุญาตในขณะนี้ ฉันยังไม่คิดว่ามันจะทำให้ปุยแม้ว่า
Mr. Xcoder

คำตอบ:


8

เยลลี่ 6 ไบต์

-*æ.¹A

ลองออนไลน์!

มันทำงานอย่างไร

-*æ.¹A  Main link. Argument: A (digit array)

-*      Raise -1 to A's digits, yielding 1 for even digits and -1 for odd ones.
    ¹   Identity; yield A.
  æ.    Take the dot product of the units and the digits.
     A  Apply absolute value.

คุณสามารถบันทึก 1 ไบต์โดยการป้อนข้อมูลเป็นรายการ
CalculatorFeline

ฉันกำลังป้อนข้อมูลเป็นรายการ
Dennis

ฉันกำลังพูดถึงการแก้ไข 2
CalculatorFeline

Raise -1 to A's digits, yielding 1 for even digits and 0 for odd ones.อืมมฉันคิดว่าคุณทำอะไร
ซัก

2
@EriktheOutgolfer Darn เกิดข้อผิดพลาด
Dennis

8

SHENZHEN สคริปต์ I / O MCxxxx, 197 (126 + 71) ไบต์

ชิป 1 (MC6000):

  • x0: ป้อนข้อมูลเป็นรายการ
  • x2: Chip 2 x1
  • x3: MC4010
mov 0 dat
j:
mov x0 acc
mov 70 x3
mov -1 x3
mov acc x3
mul x3
mov acc x2
mov dat acc
add 1
tlt acc 3
mov acc dat
+jmp j
slx x0

ชิป 2 (MC4000):

  • p0: เอาต์พุต
  • x0: MC4010
  • x1: ชิป 1 x2
mov x1 acc
add x1
add x1
mov 30 x0
mov 0 x0
mov acc x0
mov x0 p0
slx x1

1
(คุณสามารถให้เรา<!-- -->แสดงความคิดเห็นเพื่อรับรหัสขวาหลังจากรายการแทนข้อความฟิลเลอร์หรือเยื้องรหัสที่มี 4 ช่องว่าง..)
จ้า


5

TI-Basic, 18 9 ไบต์

abs(sum((-1)^AnsAns

คำอธิบาย

คูณแต่ละหลักในรายการด้วย -1 ถึงกำลังของมันโดยลบล้างแต่ละหลักแปลกก่อนที่จะสรุป


4

C (gcc) , 59 58 57 ไบต์

i;f(char*v){for(i=0;*v;v++)i+=*v%2?*v-48:48-*v;v=abs(i);}

ลองออนไลน์!


1
ถ้าช่วยได้ฉันเปลี่ยนกฎแล้วและตอนนี้คุณสามารถรับข้อมูลเป็นรายการได้ หวังว่าจะช่วยประหยัดไบต์ ฉันไม่รู้จัก C ดังนั้นจึงเป็นเพียงข้อเสนอแนะ
Mr. Xcoder

4

R, 30 29 ไบต์

abs(sum((d=scan())-2*d*d%%2))

d = scan() ใช้หมายเลขอินพุตหนึ่งหลักหลังจากที่อื่น

-1 ไบต์ขอบคุณ @Giuseppe!


มันยอดเยี่ยมมาก! มีการบันทึก 1 ไบต์ แต่:abs(sum((d=scan())-2*d*d%%2))
Giuseppe

@Giuseppe ขอบคุณเคล็ดลับดีแก้ไข!
Nutle

4

C #, 57 ไบต์

namespace System.Linq{i=>Math.Abs(i.Sum(n=>n%2<1?n:-n))}

นำเข้าiและรวมจำนวนเต็มด้วยการเปลี่ยนอัตราเดิมพันเป็นค่าลบ


คำตอบแรกที่นี่ ไม่มีเงื่อนงำหากฉันต้องการห่อสิ่งนี้ทั้งหมดไว้ในโปรแกรม C # จริงและนับจำนวนไบต์เหล่านั้นด้วย
TyCobb

คุณต้องรวมสำเร็จรูปnamespace System.Linq{และสร้างฟังก์ชั่นจริง ดูคำตอบ C # อื่น ๆ สำหรับการอ้างอิง
Mr. Xcoder

@ Mr.Xcoder ขอบคุณสำหรับข้อมูล คิดว่าฉันได้รับ เกือบเป็นสองเท่าของฉันนับไบต์ = (lol
TyCobb

ใช่ C # ไม่ใช่ภาษากอล์ฟที่ดีที่สุด
Mr. Xcoder

@ Mr.Xcoder Nope แต่ฉันคิดว่ากฎได้ผ่อนคลายเพราะผมเห็นบางรุ่นในหน้าแรกได้โดยไม่ต้องสิ่ง namespace Mainและไม่ได้เห็น เหตุผลเดียวที่ฉันคิดว่าฉันตอบด้วย โอ้
TyCobb

4

Mathematica ขนาด 20 ไบต์

Abs@Tr[(-1)^(g=#)g]&

ใช้เป็นรายการของตัวเลข

thanx พิเศษเป็น @LLAMAMNYP เพื่อแจ้งให้ฉันทราบเกี่ยวกับ "กฎใหม่"


เอาชนะฉันไป! :) *คุณอาจไม่จำเป็นต้องใช้
Greg Martin

ตอนนี้ OP ได้ผ่อนคลายข้อกำหนดของรหัสของคุณอาจสั้นกว่าเล็กน้อย +1
LLlAMnYP


3

Neim , 7 ไบต์

ΓDᛃΞ𝐍}𝐬

คำอธิบาย:

Γ        Apply the following to each element in the input array
 D         Duplicate
  ᛃ        Modulo 2, then perform logical NOT
   Ξ       If truthy, then:
    𝐍        Multiply by -1
      }  Close all currently running loops/conditionals etc
       𝐬 Sum the resulting array

ใครไม่มีบิวอินในตัวที่ mods ด้วย 2 จากนั้นก็ไม่มีผลกับเหตุผล?
caird coinheringaahing

@cairdcoinheringaahing เป็นพื้น 'ตรวจสอบว่าแม้'
Okx

3

APL, 8 ไบต์

|⊢+.ׯ1*⊢

ลองออนไลน์!

อย่างไร?

¯1*⊢- -1 nสำหรับnใน

[ 4 5 91 ¯1 ¯1]

⊢+.×- คูณทวีคูณด้วยoแล้วรวม

[ +/ 4 5 9 × 1 ¯1 ¯1→การ+/ 4 ¯5 ¯9→การ¯10]

| - ค่าสัมบูรณ์


คุณช่วยระบุสภาพแวดล้อมการทดสอบได้ไหม?
นาย Xcoder

@ Mr.Xcoder เพิ่ม
Uriel

|⊢+.ׯ1*⊢ด้วยข้อมูลจำเพาะอินพุตใหม่
อดัม

@ Adámขอบคุณ ไม่น่าเชื่อว่าฉันจะพลาดผลิตภัณฑ์
Uriel

คุณสามารถให้รายละเอียดเพิ่มเติมในคำอธิบายได้หรือไม่ สามารถเปลี่ยนวิธีการนี้เป็น J ได้ไหม? ขณะนี้ฉันกำลังใช้รหัส (ดูคำตอบของฉัน) แต่วิธีการนี้อาจโกนทิ้งบางไบต์ ...
Jonah

3

JavaScript (ES6), 43 38 ไบต์

จะเข้าเป็นสตริงอาร์เรย์ของตัวเลข

a=>a.map(d=>s+=d&1?d:-d,s=0)&&s>0?s:-s

กรณีทดสอบ


3

แก้ไข: แนวทางที่เน้นสนามกอล์ฟมากขึ้น:

EXCEL, 42 36 29 ไบต์

บันทึกไปแล้ว 6 ไบต์ด้วย Magic Octopus Urn บันทึกแล้ว 7 ไบต์โดยใช้วิธี Dennis '-1 ^ (ซึ่งฉันเพิ่งเรียนรู้ทำงานในอาร์เรย์ใน excel)

=ABS(SUMPRODUCT(A:A,-1^A:A))

ทำรายการจำนวนเต็มในคอลัมน์ A สำหรับอินพุต อาจจะสามารถเล่นกอล์ฟต่อไปได้หรือโดยการใช้รุ่นสตริงโดยใช้สตริงใน A1 สำหรับอินพุต

EXCEL, 256 ไบต์

=ABS(LEN(SUBSTITUTE(A1,1,""))-2*LEN(SUBSTITUTE(A1,2,""))+3*LEN(SUBSTITUTE(A1,3,""))-4*LEN(SUBSTITUTE(A1,4,""))+5*LEN(SUBSTITUTE(A1,5,""))-6*LEN(SUBSTITUTE(A1,6,""))+7*LEN(SUBSTITUTE(A1,7,""))-8*LEN(SUBSTITUTE(A1,8,""))+9*LEN(SUBSTITUTE(A1,9,""))-5*LEN(A1))

enter image description here


1
ข้อจำกัดความรับผิดชอบใช้งานได้กับตัวเลขที่มีความยาวน้อยกว่า 100 เท่านั้น
Magic Octopus Urn

1
การสลับเป็น A: A จะบันทึก 6 ไบต์และลบปัญหานั้น
Mark

คำวิจารณ์เชิงสร้างสรรค์ของฉันไม่ค่อยบันทึกไบต์ +1 สำหรับคุณรู้เรื่อง Excel
Magic Octopus Urn

Also, due to You may take input as a String, as an Integer or as a list of digits. your 42 byte answer should be the answer you use.
Magic Octopus Urn

The first was a humorous attempt, but I'll switch them around.
Mark


2

Husk, 7 bytes

≠0ṁṠ!¡_

Try it online!

Takes a list of digits as input.

ยังคงหายไป "abs" builtin แต่ผลลัพธ์ที่ดีเหมือนกัน :)

คำอธิบาย

Ṡ!¡_เป็นฟังก์ชั่นที่ใช้เวลาจำนวนหนึ่งnและจากนั้นใช้n-1เวลาฟังก์ชั่น_(ปฏิเสธ) nเพื่อ ผลนี้ในnสำหรับแปลกnหรือแม้แต่-nn

ใช้ฟังก์ชั่นกับองค์ประกอบแต่ละรายการและสรุปผล

≠0 ส่งคืนความแตกต่างที่แน่นอนระหว่างตัวเลขและ 0


2

05AB1E , 6 ไบต์

ขอบคุณเดนนิสสำหรับเคล็ดลับการใช้พลังงาน -1 ใช้อินพุตเป็นรายการของตัวเลข

®sm*OÄ

ลองออนไลน์!

คำอธิบาย

®sm*OÄ                                               Example [4, 5, 9]
®      # Push -1                                   % STACK: -1
 sm    # Take -1 to the power of every number      % STACK: [1, -1, -1]
         in the input list 
   *   # Multiply with original input              % Multiply [1, -1, -1] with [4, 5, 9] results in STACK: [4, -5, -9]
    O  # Sum them all together                     % STACK: -10
     Ä # Absolute value                            % STACK: 10
       # Implicit print

I can´t follow the explanation. Would you add an example please.
Titus

@Titus there you go. Hope it helps :)
Datboi

And here I was with È2*<*O like a filthy casual.
Magic Octopus Urn

2

PHP, 51 bytes

while(~$n=$argn[$i++])$s+=$n&1?$n:-$n;echo abs($s);

adds digit to $s if odd, subtracts if even. Run as pipe with -nR.

or

while(~$n=$argn[$i++])$s+=(-1)**$n*$n;echo abs($s);

using Dennis´ -1 power trick.



2

PHP, 54 bytes

for(;~$n=$argn[$i++];)${eo[$n&1]}+=$n;echo abs($e-$o);

Try it online!

PHP, 57 bytes

store the even and odd sums in an array

for(;~$n=$argn[$i++];)$r[$n&1]+=$n;echo abs($r[0]-$r[1]);

Try it online!

PHP, 57 bytes

store the even and odd sums in two variables

for(;~$n=$argn[$i++];)$n&1?$o+=$n:$e+=$n;echo abs($e-$o);

Try it online!


54 bytes: odd sum in ${1} and even sum in ${0}: while(~$n=$argn[$i++])${$n&1}+=$n;echo abs(${1}-${0});
Titus

@Titus nice I think ` for(;~$n=$argn[$i++];)${eo[$n&1]}+=$n;echo abs($e-$o);` is also a nice variant. Or we can do it more nathematical for(;~$n=$argn[$i++];$s+=$n)$u+=($n&1)*$n;echo abs($s-2*$u); and for(;~$n=$argn[$i++];)$u+=(($n&1)-.5)*2*$n;echo abs($u); is an interesting way
Jörg Hülsermann


1

Perl 6, 28 bytes

{abs sum $_ Z*.map(*%2*2-1)}

Try it online!

Takes a list of digits as input.

  • $_ is the input argument.
  • .map(* % 2 * 2 - 1) maps each digit to either 1 or -1 depending on whether the digit is odd or even, respectively.
  • Z* zips the original list of digits with the even/odd list using multiplication.

1

Braingolf, 18 bytes

{.2%?M|}&+v&+c-!s*

Try it online!

Takes input as a list of digits

Explanation

{.2%?M|}&+v&+c-!s*  Implicit input from commandline args
{......}            Foreach loop, runs on each item in the stack..
 .2%                ..Parity check, push 1 if odd, 0 if even
    ?               ..If last item != 0 (pops last item)..
     M              ....Move last item to next stack
      |             ..Endif
        &+          Sum entire stack
          v&+       Switch to next stack and sum entire stack
             c-     Collapse into stack1 and subtract
               !s   Sign check, push 1 if last item is positive, -1 if last item is
                    negative, 0 if last item is 0
                 *  Multiply last item by sign, gets absolute value
                    Implicit output

1

R, 72 43 bytes

b=(d=scan())%%2<1;abs(sum(d[b])-sum(d[!b]))

First, d = scan() takes the number as input, one digit after the other (thanks to @Giuseppe comment !)
Then, b = d %% 2 <1 associates to b a TRUE or FALSE value at each index depending on the digits' parity. Therefore, b values are TRUE for even numbers, and !b are TRUE for odd values.

Finaly, abs(sum(d[b]) - sum(d[!b])) does the job.


<1 is one byte shorter than ==0, but note that you may take input as a list of digits as well.
Giuseppe

@Giuseppe Well spotted ! Thanks !
Frédéric





1

x86-64 Machine Code, 30 bytes

31 C0 99 8B 4C B7 FC F6 C1 01 74 04 01 CA EB 02 01 C8 FF CE 75 ED 29 D0 99 31 D0 29 D0 C3

The above code defines a function that accepts a list/array of integer digits and returns the absolute difference between the sum of its even digits and the sum of its odd digits.

As in C, assembly language doesn't implement lists or arrays as first-class types, but rather represents them as a combination of a pointer and a length. Therefore, I have arranged for this function to accept two parameters: the first is a pointer to the beginning of the list of digits, and the second is an integer specifying the total length of the list (total number of digits, one-indexed).

The function conforms to the System V AMD64 calling convention, which is standard on Gnu/UNIX systems. In particular, the first parameter (pointer to the beginning of the list) is passed in RDI (as this is 64-bit code, it is a 64-bit pointer), and the second parameter (length of the list) is passed in ESI (this is only a 32-bit value, because that's more than enough digits to play with, and naturally it is assumed to be non-zero). The result is returned in the EAX register.

If it's any clearer, this would be the C prototype (and you can use this to call the function from C):

int OddsAndEvens(int *ptrDigits, int length);

Ungolfed assembly mnemonics:

; parameter 1 (RDI) == pointer to list of integer digits
; parameter 2 (ESI) == number of integer digits in list (assumes non-zero, of course)
OddsAndEvens:
   xor  eax, eax              ; EAX = 0 (accumulator for evens)
   cdq                        ; EDX = 0 (accumulator for odds)
.IterateDigits:
   mov  ecx, [rdi+rsi*4-4]    ; load next digit from list
   test cl, 1                 ; test last bit to see if even or odd
   jz   .IsEven               ; jump if last bit == 0 (even)
.IsOdd:                       ; fall through if last bit != 0 (odd)
   add  edx, ecx              ; add value to odds accumulator
   jmp  .Continue             ; keep looping
.IsEven:
   add  eax, ecx              ; add value to evens accumulator
.Continue:                    ; fall through
   dec  esi                   ; decrement count of digits in list
   jnz  .IterateDigits        ; keep looping as long as there are digits left

   sub  eax, edx              ; subtract odds accumulator from evens accumulator

   ; abs
   cdq                        ; sign-extend EAX into EDX
   xor  eax, edx              ; XOR sign bit in with the number
   sub  eax, edx              ; subtract sign bit

   ret                        ; return with final result in EAX

Here's a brief walk-through of the code:

  • First, we zero out the EAX and EDX registers, which will be used to hold the sum totals of even and odd digits. The EAX register is cleared by XORing it with itself (2 bytes), and then the EDX register is cleared by sign-extending the EAX into it (CDQ, 1 byte).
  • Then, we go into the loop that iterates through all of the digits passed in the array. It retrieves a digit, tests to see if it is even or odd (by testing the least-significant bit, which will be 0 if the value is even or 1 if it is odd), and then jumps or falls through accordingly, adding that value to the appropriate accumulator. At the bottom of the loop, we decrement the digit counter (ESI) and continue looping as long as it is non-zero (i.e., as long as there are more digits left in the list to be retrieved).

    The only thing tricky here is the initial MOV instruction, which uses the most complex addressing mode possible on x86.* It takes RDI as the base register (the pointer to the beginning of the list), scales RSI (the length counter, which serves as the index) by 4 (the size of an integer, in bytes) and adds that to the base, and then subtracts 4 from the total (because the length counter is one-based and we need the offset to be zero-based). This gives the address of the digit in the array, which is then loaded into the ECX register.

  • After the loop has finished, we do the subtraction of the odds from the evens (EAX -= EDX).

  • Finally, we compute the absolute value using a common trick—the same one used by most C compilers for the abs function. I won't go into details about how this trick works here; see code comments for hints, or do a web search.

__
* The code can be re-written to use simpler addressing modes, but it doesn't make it any shorter. I was able to come up with an alternative implementation that dereferenced RDI and incremented it by 8 each time through the loop, but because you still have to decrement the counter in ESI, this turned out to be the same 30 bytes. What had initially given me hope is that add eax, DWORD PTR [rdi] is only 2 bytes, the same as adding two enregistered values. Here is that implementation, if only to save anyone attempting to outgolf me some effort :-)

                    OddsAndEvens_Alt:
31 C0                   xor    eax, eax
99                      cdq
                    .IterateDigits:
F6 07 01                test   BYTE PTR [rdi], 1
74 04                   je     .IsEven
                    .IsOdd:
03 17                   add    edx, DWORD PTR [rdi]
EB 02                   jmp    .Continue
                    .IsEven:
03 07                   add    eax, DWORD PTR [rdi]
                    .Continue:
48 83 C7 08             add    rdi, 8
FF CE                   dec    esi
75 ED                   jne    .IterateDigits
29 D0                   sub    eax, edx
99                      cdq
31 D0                   xor    eax, edx
29 D0                   sub    eax, edx
C3                      ret


1

TI-BASIC, 11 6 bytes

abs(sum(Anscos(πAns

Takes input as a list. i²^Ans saves two bytes over (-1)^Ans because we don't need the parentheses.

abs(sum(Anscos(πAns
           cos(πAns                  1 for evens, -1 for odds
        Ans                          Multiply by original list
abs(sum(                             Sum the list and take absolute value, which also
                                     fixes rounding errors from cos(.

1

J, 14 bytes

|-/(2&|+//.[),

Try it online!

explanation

|                absolute value of
 -/              the difference between
                 the items on the list returned by this fork
   (2&|          is an item odd? (1 for yes, 0 for no)
       +//.      the "key" verb /. which partitions on above (even / odd) then sums
           [)    identity, ie, the list of digits passed
             ,   turn it into a list (to handle 1 element case)
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.