Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Diego Madison #68

Open
wants to merge 3 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
86 changes: 67 additions & 19 deletions NOCList.playground/Contents.swift
Original file line number Diff line number Diff line change
Expand Up @@ -29,56 +29,104 @@ This message will self destruct in 5 seconds.
*/
//: ## Step 1
//: Create constants for each of the above agents and store all their information in a tuple.



//: ## Step 2
//: Place the above constants inside an array. Declare this array as a constant as well.



let agent1 = (coverName: "Ethan Hunt", realName: "Tom Cruise", accessLevel: 8, compromised: false)
let agent2 = (coverName: "Jim Phelps", realName: "Jon Voight", accessLevel: 9, compromised: true)
let agent3 = (coverName: "Claire Phelps", realName: "Emmanuelle Beart", accessLevel: 5, compromised: false)
let agent4 = (coverName: "Eugene Kittridge", realName: "Henry Czerny", accessLevel: 10, compromised: true)
let agent5 = (coverName: "Franz Krieger", realName: "Jean Reno", accessLevel: 4, compromised: false)
let agent6 = (coverName: "Luther Stickell", realName: "Ving Rhames", accessLevel: 4, compromised: false)
let agent7 = (coverName: "Sarah Davies", realName: "Kristin Scott Thomas", accessLevel: 5, compromised: true)
let agent8 = (coverName: "Max RotGrab", realName: "Vanessa Redgrave", accessLevel: 4, compromised: false)
let agent9 = (coverName: "Hannah Williams", realName: "Ingeborga Dapkūnaitė", accessLevel: 5, compromised: true)
let agent10 = (coverName: "Jack Harmon", realName: "Emilio Estevez", accessLevel: 6, compromised: true)
let agent11 = (coverName: "Frank Barnes", realName: "Dale Dye", accessLevel: 9, compromised: false)


// Step 2 place the above constants inside an array and declare as an array as well

let agentArray = [agent1, agent2, agent3, agent4, agent5, agent6, agent7, agent8, agent9, agent10, agent11]
//: ## Step 3
//: Create a function that calculates the total number of compromised agents. Inside the function, iterate over the array of agents to determine which ones are compromised. Return the total count.

func compromisedAgent() -> Int {
var countOfCompromised = 0
for compromised in agentArray {
if compromised.3 == true {
countOfCompromised += 1
}
}
return countOfCompromised
}

//Step 4 Call the above function to find the total number of compromised agents and then print a sentence that says "# agents have been compromised!" using string interpolation

//: ## Step 4
//: Call the above function to find the total number of compromised agents and then print a sentence that says "# agents have been compromised!" using string interpolation.

print("\(compromisedAgent()) agents have been comprimised!")


//: ## Step 5
//: Create a function called "findCleanAgents" that both prints the cover names of all uncompromised agents, as well as returns an array of agents that are uncompromised.

func findCleanAgents() -> Array<Any> {
var cleanAgentArray: [(coverName: String, realName: String, accessLevel: Int, compromised: Bool)] = []
for uncompromised in agentArray {
if uncompromised.3 == false {
cleanAgentArray.append(uncompromised); print(uncompromised.0)
}
}

return cleanAgentArray
}


//: ## Step 6
//: Call the above function to find the total number of clean agents and print a message that says "# clean agents out of # total agents." Use the total number of agents in the array from step 2 as the second number in the string.

print("\(findCleanAgents().count) clean agents out of \(agentArray.count)")


//: ## Step 7
//: Create a function called "findHighRisk" that prints out the real names and access levels of agents with level 8 or higher. If one of these agents is also currently compromised, add `**WARNING** **COMPROMISED**` to the end of the string that includes their name and access level.
//: - Example: `Jon Voight, level: 9 **WARNING** **COMPROMISED**`


func findHighRisk() {
for highRisk in agentArray {
if highRisk.accessLevel >= 8, highRisk.compromised == true {
print(highRisk.realName, highRisk.accessLevel, "**WARNING** **COMPROMISED**")
} else if highRisk.accessLevel >= 8, highRisk.compromised == false {
print(highRisk.realName, highRisk.accessLevel)
}

}
}

//: ## Step 8
//: Call the above function and check the output in the console to ensure it is functioning properly.


findHighRisk()

//: ## Step 9
//: Create a function that finds totals for low, mid, and high level agents. Low level agents are 4 or lower, mid are 5-7, and high level agents are 8 or above. Iterate over each agent and use a `switch` statement to determine their level group. At the end of the function, print a statement like the following: "# low level agents, # mid level agents, and # high level agents"

func agentLevelGrouper() {
var lowLevel = 0
var midLevel = 0
var highLevel = 0
for groups in agentArray {
switch groups.accessLevel {
case 0...4:
lowLevel += 1
case 5...7:
midLevel += 1
default:
highLevel += 1
}

}
print("\(lowLevel) low level agents \(midLevel) mid level agents \(highLevel) high level agents" )
}


//: ## Step 10
//: Call the above function and check its output in the console.

agentLevelGrouper()


//: ## Step 11 (Optional)
//: Create and call a function that prints the cover names and access levels of all agents, but the list should be sorted by access level, in ascending order.


Binary file not shown.
Binary file not shown.