Welcome to the Treehouse Community
Want to collaborate on code errors? Have bugs you need feedback on? Looking for an extra set of eyes on your latest project? Get support with fellow developers, designers, and programmers of all backgrounds and skill levels here with the Treehouse Community! While you're at it, check out some resources Treehouse students have shared here.
Looking to learn something new?
Treehouse offers a seven day free trial for new students. Get access to thousands of hours of content and join thousands of Treehouse students and alumni in the community today.
Start your free trialJason Teo
Courses Plus Student 8,398 PointsI can't solve this.
Any help? Thanks!
/**
For this code challenge, letβs define a math operation as a function that
carries out some work on two integers and returns an integer as well. An
example is the function below, `differenceBetweenNumbers`, which takes two
integers and calculates the difference between the numbers. After calculating,
it returns the difference.
*/
func differenceBetweenNumbers(a: Int, b:Int) -> (Int) {
return a - b
}
// Enter your code below
func mathOperation((differenceBetweenNumbers: (Int, Int) -> Int, a: Int, b: Int) -> (Int,Int) -> (Int) {
return differenceBetweenNumbers(a, b)
}
2 Answers
Martin Wildfeuer
Courses Plus Student 11,071 PointsFirst of all, the return type of mathOperation
is wrong. mathOperation
should only return a single Int, and so does differenceBetweenNumbers
. Therefore mathOperation
should have a return type of -> Int
instead of -> (Int,Int) -> (Int)
.
Moreover, it is not a good idea to name the first parameter of your mathOperation
function differenceBetweenNumbers
. That is because there already is a function named differenceBetweenNumbers
. Within the scope of your mathOperation
function, you are "shadowing" the outside function name with the parameter name, thus it is not possible to call the "outside" function anymore.
That might not be a problem with this example, but in general you should not use the same name for variables/constants/parameters and functions. so the correct function should look something like this:
func mathOperation(mathOp: (Int, Int) -> Int, a: Int, b: Int) -> Int {
return mathOp(a, b)
}
Hope this helps! Happy coding :)
Jason Teo
Courses Plus Student 8,398 PointsThank you so much!
Martin Wildfeuer
Courses Plus Student 11,071 PointsThe call looks good! Make sure your mathOperation
return type doesn't have parenthesis, like in my answer. Though this is not wrong, code check here seems to be picky about it.