Communities

Writing
Writing
Codidact Meta
Codidact Meta
The Great Outdoors
The Great Outdoors
Photography & Video
Photography & Video
Scientific Speculation
Scientific Speculation
Cooking
Cooking
Electrical Engineering
Electrical Engineering
Judaism
Judaism
Languages & Linguistics
Languages & Linguistics
Software Development
Software Development
Mathematics
Mathematics
Christianity
Christianity
Code Golf
Code Golf
Music
Music
Physics
Physics
Linux Systems
Linux Systems
Power Users
Power Users
Tabletop RPGs
Tabletop RPGs
Community Proposals
Community Proposals
tag:snake search within a tag
answers:0 unanswered questions
user:xxxx search by author id
score:0.5 posts with 0.5+ score
"snake oil" exact phrase
votes:4 posts with 4+ votes
created:<1w created < 1 week ago
post_type:xxxx type of post
Search help
Notifications
Mark all as read See all your notifications »
Challenges

Comments on Operation "Find The Operator"

Parent

Operation "Find The Operator"

+7
−0

Challenge

Make a program that takes input of 3 non-negative integers: a result and 2 other values that once calculated results to the 3rd value.

  • The program must figure out how to get the 2 first numbers to equivalence itself with the 3rd. It could be either addition, subtraction, multiplication, integer division, modulo and exponentiation.
  • You can't change the places of the 2 variables when building the equation, meaning you can't get some value by intertwining in the methods excluding addition and multiplication.
  • The returning value is the operator that makes the equation true (it's best to use some distinguishable character to separate it from the other methods).
  • Use whatever characters you want to use to determine the method that makes the equation truthy.
  • If multiple operators make the equation truthy, then output them in any order.
  • What makes it true? If an equation exists within the 2 numbers that results to the value of the 3rd.
  • What to return when it's false? Something but not nothing (whitespaces and newlines aren't allowed as such output).
  • This is code-golf so the shortest program wins!

Test Cases

# Input (#, #, #)
// Output (+-*/%^ or .)

2 3 5
+

7 3 2
/

9 8 4
.

1 2 2
*

2 2 4
+ * ^

14 6 8
-

5 0 2
.

0 0 1
^

8 4 0
%

0 0 0
+ - *
History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.
Why should this post be closed?

0 comment threads

Post
+3
−0

Python 3, 106 91 bytes

Saved 15 bytes thanks to Moshi in the comments

lambda a,b,c:[p for p in"+ - * // % **".split()if(p in'+-**'or b)and eval(f"{a}{p}{b}")==c]

Try it online!

History
Why does this post require attention from curators or moderators?
You might want to add some details to your flag.

2 comment threads

Further improvements (1 comment)
91 bytes with list comprehension (2 comments)
Further improvements
m90‭ wrote over 3 years ago

83, using a different way of specifying the operators and comparison chaining: lambda a,b,c:[p for p in[*"+-*%","//","**"]if('%'<p<'.')>-b<=c==eval(f"{a}{p}{b}")]

80, similar, producing slightly different output, which I think is allowed, but it's not completely clear: lambda a,b,c:[p for p in[*"+-*%"," //","**"]if('%'<p)>-b<=c==eval(f"{a}{p}{b}")]