Skip to content
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
10 changes: 10 additions & 0 deletions Sprint-2/1-key-errors/0.js
Original file line number Diff line number Diff line change
@@ -1,13 +1,23 @@
// Predict and explain first...
// =============> write your prediction here
// when running the code there will be a syntax error because the `str` being a function name has already been declared
// so it cant be returned .so the return variable should have another name

// call the function capitalise with a string input
// interpret the error message and figure out why an error is occurring
//Uncaught SyntaxError: Identifier 'str' has already been declared


function capitalise(str) {
let str = `${str[0].toUpperCase()}${str.slice(1)}`;
return str;
}

// =============> write your explanation here
// there is an error in the code because the `str` is declared twice and there are unexpected token '}'.

// =============> write your new code here
function capitalise (str) {
return `${str[0].toUpperCase()}${str.slice(1)}`;
}

11 changes: 10 additions & 1 deletion Sprint-2/1-key-errors/1.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,9 @@
// Predict and explain first...
// the will be answer of the percentage printed on the console.log.because the function has been declared.

// Why will an error occur when this program runs?
// =============> write your prediction here
//there will be a code error because of the function has been declared twice.

// Try playing computer with the example to work out what is going on

Expand All @@ -15,6 +17,13 @@ function convertToPercentage(decimalNumber) {
console.log(decimalNumber);

// =============> write your explanation here

//when a function is called a value it given to the parameter.
// Finally, correct the code to fix the problem
// =============> write your new code here

function convertToPercentage(decimalNumber){
const percentage = `${decimalNumber * 100 }%`;
return percentage;
}
console.log (convertToPercentage(0.5)) //50
console.log (convertToPercentage(0.25)) //25%
18 changes: 12 additions & 6 deletions Sprint-2/1-key-errors/2.js
Original file line number Diff line number Diff line change
@@ -1,20 +1,26 @@

// Predict and explain first BEFORE you run any code...

// the will be an error when this code runs because the retrun varaible has not been assigined by a value and there function has not declared a variable.
// this function should square any number but instead we're going to get an error

// =============> write your prediction of the error here
// synch equation

function square(3) {
return num * num;
}

// =============> write the error message here
// Uncaught SyntaxError: Unexpected number
// > return num * num;
// return num * num;

// =============> explain this error message here
//Uncaught SyntaxError: Illegal return statement

// =============> explain this error message here
// the error is simply saying that the return variable has not been assigned by a value.`illegal statement`.
// Finally, correct the code to fix the problem

// =============> write your new code here


function square (num){
return num * num;
}
console.log (square(3)) // 9
14 changes: 11 additions & 3 deletions Sprint-2/2-mandatory-debug/0.js
Original file line number Diff line number Diff line change
@@ -1,14 +1,22 @@
// Predict and explain first...

// =============> write your prediction here
// I predict that the function expression will run a nerro because the are errors in the code .such as the concole.log in line 6.


function multiply(a, b) {
console.log(a * b);
concole.lpg( a* b);

}

console.log(`The result of multiplying 10 and 32 is ${multiply(10, 32)}`);

// =============> write your explanation here

// console.log prints out information it does not return any varable to its function.hence the syntax error.
// console.log cant read unprovided information.
// Finally, correct the code to fix the problem
// =============> write your new code here
function multiply (a,b){
if (a===10 && b===32){
let result =a * b ;
}
}
Comment on lines 11 to +22

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you tested your implementation to see if it can return the product of its parameters?

6 changes: 6 additions & 0 deletions Sprint-2/2-mandatory-debug/1.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
// Predict and explain first...
// =============> write your prediction here
//Js doesnt understand this code so it will read as an error because the return varable has not been aissinged any variable.

function sum(a, b) {
return;
Expand All @@ -9,5 +10,10 @@ function sum(a, b) {
console.log(`The sum of 10 and 32 is ${sum(10, 32)}`);

// =============> write your explanation here
// js does not read values not assigned to any variable so the will be a syntax error not allowing the code to read .
// Finally, correct the code to fix the problem
// =============> write your new code here
function sum (a ,b){
return a + b ;
}
console.log(`The sum of 10 and 32 is ${sum(10.32)}`);
14 changes: 12 additions & 2 deletions Sprint-2/2-mandatory-debug/2.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
// Predict and explain first...

// Predict and explain first..
// Predict the output of the following code:
// =============> Write your prediction here
// i predict that the output will be 3 for all the numbers passed to the function because the function is not using the parameter
// passed to it instead it is using the variable num which is 103 so it will always return 3 as the last digit of any number passed to it.

const num = 103;

Expand All @@ -15,10 +16,19 @@ console.log(`The last digit of 806 is ${getLastDigit(806)}`);

// Now run the code and compare the output to your prediction
// =============> write the output here
// The last digit of 42 is 3
// The last digit of 105 is 3
// the last digit of 806 is 3

// Explain why the output is the way it is
// =============> write your explanation here
// The output is the way it is because the function getlastDigit is not using the parameter passed to it.instead it is using the variable num which is 103.
// Finally, correct the code to fix the problem
// =============> write your new code here
// the function getLastDigit(num){
// return num.string().slice(-1);}

// This program should tell the user the last digit of each number.
// Explain why getLastDigit is not working properly - correct the problem
// this is because the function getLastDigit is not using the parameter passed to it.
// instead it is using the variable num which is 103. so it will always return 3 as the last digit of any number passed to it.s
6 changes: 5 additions & 1 deletion Sprint-2/3-mandatory-implement/1-bmi.js
Original file line number Diff line number Diff line change
Expand Up @@ -16,4 +16,8 @@

function calculateBMI(weight, height) {
// return the BMI of someone based off their weight and height
}
return Number((weight/(height *height)).toFixed(1));
}



7 changes: 7 additions & 0 deletions Sprint-2/3-mandatory-implement/2-cases.js
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,10 @@
// You will need to come up with an appropriate name for the function
// Use the MDN string documentation to help you find a solution
// This might help https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/toUpperCase

function touppersneakers (input){

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could you look up the naming conventions in JavaScript? In particular,

  • Variable and function names
  • Class and Types names
  • Named constants

Then, update the function name according to those conventions.

return input.trim().replace(/\s+/g, "_").touppercase();
}
console.log(touppersneakers("hello there"));//Hello There
Comment on lines +18 to +21

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you tested your implementation to see if it works as expected?

console.log(touppersneakers("lord of the rings")); // lord of the rings
console.log(touppersneakers("good morning")); // GOOD MORNING
18 changes: 18 additions & 0 deletions Sprint-2/3-mandatory-implement/3-to-pounds.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,3 +4,21 @@
// You will need to declare a function called toPounds with an appropriately named parameter.

// You should call this function a number of times to check it works for different inputs



function toSnakeCase(str) {
const pecestringwithouttrailingp = pencestring.substring(0,pencestring.length -1);
const padded penceNumberstring = pencestringWithoutTrailingP.padstart(3,"0");
const pounds = paddedpenceNumberString.substring(0, paddedpencenumberstring.length-2);
const pencr= paddedpencenumberstring.substring(paddedpencenumberstring.length -2)
.padEnd(2,"0");
return £${pounds}.${pence}`;
}
// test the function with different inputs
consloe.log(topounds("399p"), // £3.99
Comment on lines +10 to +19

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Have you tested this implementation?

4console.log(toPounds("9p")); // £0.09
console.log(toPounds("99p")); // £0.99
console.log(toPounds("1234p")); // £12.34


7 changes: 7 additions & 0 deletions Sprint-2/4-mandatory-interpret/time-format.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,17 +22,24 @@ function formatTimeDisplay(seconds) {

// a) When formatTimeDisplay is called how many times will pad be called?
// =============> write your answer here
// pad will be called 3 times, once for totalHours, once for remainingMinutes, and once for remainingSeconds.

// Call formatTimeDisplay with an input of 61, now answer the following:

// b) What is the value assigned to num when pad is called for the first time?
// =============> write your answer here
// The value assigned to num when pad is called for the first time is 0, which is the value of totalHours when the input is 61 seconds.

// c) What is the return value of pad is called for the first time?
// =============> write your answer here
// The return value of pad when it is called for the first time is "00", which is the padded string representation of totalHours (0) when the input is 61 seconds.

// d) What is the value assigned to num when pad is called for the last time in this program? Explain your answer
// =============> write your answer here
// The value assigned to num when pad is called for the last time in this program is 1, which is the value of remainingSeconds when the input is 61 seconds.
// This is because 61 seconds is equal to 1 minute and 1 second, so the remaining seconds after calculating total minutes and hours is 1.

// e) What is the return value of pad when it is called for the last time in this program? Explain your answer
// =============> write your answer here
// The return value of pad when it is called for the last time in this program is "01", which is the padded string representation of remainingSeconds (1)
// when the input is 61 seconds.
79 changes: 69 additions & 10 deletions Sprint-2/5-stretch-extend/format-time.js
Original file line number Diff line number Diff line change
@@ -1,25 +1,84 @@
// This is the latest solution to the problem from the prep.
// Make sure to do the prep before you do the coursework
// Your task is to write tests for as many different groups of input data or edge cases as you can, and fix any bugs you find.

;
function formatAs12HourClock(time) {
const hours = Number(time.slice(0, 2));
const minutes = time.slice(3, 5);
if (h)

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

What is this?


if (hours === 0) {
return `12:${minutes} am`;
}

if (hours === 12) {
return `12:${minutes} pm`;
}

if (hours > 12) {
return `${hours - 12}:00 pm`;
return `${hours - 12}:${minutes} pm`;
}

return `${time} am`;
Comment on lines 18 to 22

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The code looks correct.

Could you update the code so that the return values of formatAs12HourClock("01:23") and formatAs12HourClock("13:23") are formatted consistently?

}

const currentOutput = formatAs12HourClock("08:00");
const targetOutput = "08:00 am";
// Existing tests
console.assert(
formatAs12HourClock("08:00") === "08:00 am",
"08:00 should be 08:00 am"
);

console.assert(
formatAs12HourClock("23:00") === "11:00 pm",
"23:00 should be 11:00 pm"
);

// Additional tests

// Midnight
console.assert(
currentOutput === targetOutput,
`current output: ${currentOutput}, target output: ${targetOutput}`
formatAs12HourClock("00:00") === "12:00 am",
"00:00 should be 12:00 am"
);

const currentOutput2 = formatAs12HourClock("23:00");
const targetOutput2 = "11:00 pm";
// Noon
console.assert(
currentOutput2 === targetOutput2,
`current output: ${currentOutput2}, target output: ${targetOutput2}`
formatAs12HourClock("12:00") === "12:00 pm",
"12:00 should be 12:00 pm"
);

// PM with minutes
console.assert(
formatAs12HourClock("13:30") === "1:30 pm",
"13:30 should be 1:30 pm"
);

// AM with minutes
console.assert(
formatAs12HourClock("09:45") === "09:45 am",
"09:45 should be 09:45 am"
);

// Last minute of the day
console.assert(
formatAs12HourClock("23:59") === "11:59 pm",
"23:59 should be 11:59 pm"
);

// One minute after midnight
console.assert(
formatAs12HourClock("00:01") === "12:01 am",
"00:01 should be 12:01 am"
);

// One minute after noon
console.assert(
formatAs12HourClock("12:01") === "12:01 pm",
"12:01 should be 12:01 pm"
);

// 1 PM
console.assert(
formatAs12HourClock("13:00") === "1:00 pm",
"13:00 should be 1:00 pm"
);
Loading