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 trial

iOS Swift 2.0 Collections and Control Flow Control Flow With Conditional Statements FizzBuzz

Aditya Gawade
Aditya Gawade
1,182 Points

tried it with and with out looping statements (for 1...100{). compiler error is in the : else{ return(n)}

Enter your FizzBuzz solution here! You will have to make some minor changes to get this to work with our editor though.

Step 1: Copy-paste your code in between the comments shown below. Your solution is going inside a function I created. Don't worry about what it does, this just allows me to verify your solution.

Step 2: Change your variable/constant name that you are checking in each step to n. For example if (n % 3 == 0). You also don't need to define n. It is defined in the function provided.

Step 3: Change all your print statements to return statements. For example: print("FizzBuzz") becomes return "FizzBuzz".

While these are very specific directions, they allow me to verify your solution precisely over a large number of possible answers.

Note: Do not worry about the default case (where the number doesn't match Fizz, Buzz, or FizzBuzz). The code in the challenge editor already takes care of that by returning the number as a string using string interpolation.

fizzBuzz.swift
func fizzBuzz(n: Int) -> String {
  // Enter your code between the two comment markers
  if (n%3 == 0) && (n%5 == 0){
  return("FizzBuzz")
  } else if (n%3 == 0){
  return("Fizz")
  } else if (n%5 == 0){
  return("Buzz")
  } else {
  return(n)}
  // End code
  return "\(n)"
}

1 Answer

Jason Anders
MOD
Jason Anders
Treehouse Moderator 145,858 Points

Hey Aditya,

While your code is syntactically correct (Nice Job!), you missed the "Note:" in the instructions to not include a default case. So if you delete the final else statement (with the return inside), you code does pass.

Keep Coding! :) :dizzy: