Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Appearance settings
Closed
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
101 changes: 100 additions & 1 deletion 101 starter-code/basic-algorithms.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,106 @@
// Names and Input
let hacker1 = "Manolo";
Copy link
Contributor

Choose a reason for hiding this comment

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

Como regla general: Uitlizar siempre const hasta que el código de error por intentar reasignar el valor.
Pero buena estructura, declarando la mayoría de las variables en la parte superior.

let hacker2;
let palindromeString;

let driverName = '';
let driverNameRev = '';
let hack1IsLong;


hacker2 = prompt("What's your name?").trim();
palindromeString = prompt('Enter a sentence').trim();


console.log("The driver's name is " + hacker1);



//Conditionals


// Lorem ipsum generator
//Check what name is longer
if (hacker1.length > hacker2.length){
console.log("The driver has the longest name, it has " + hacker1.length + " characters");
hack1IsLong = true;
} else if (hacker1.length < hacker2.length){
console.log("Yo, navigator got the longest name, it has " + hacker2.length + " characters");
hack1IsLong = false;
} else{
console.log("Wow, you both have equally long names, " + hacker1.length + " characters!!");
hack1IsLong = true;
}

//Separate characters
for (let i = 0; i< hacker1.length; i++){
driverName += hacker1[i].toUpperCase() + ' ';
}

console.log(driverName);

//Reverse the name
driverNameRev = reverseString(hacker1);

function reverseString(stringWords){
let reversedString = '';
for (let i = stringWords.length-1; i>= 0; i--){
reversedString += stringWords[i];
}
return reversedString;
}

console.log(driverNameRev);


//Lexicographic order
if (hacker1.length > hacker2.length){
sortNames(hacker2.length, "Yo, the navigator goes first definitely");
}else if (hacker1.length < hacker2.length){
sortNames(hacker1.length, "The driver's name goes first");
} else{
sortNames(hacker1.length, "What?! You both got the same name?");
}

function sortNames(lengthName, finalMessage){
for (let i = 0; i<lengthName;i++){
if (hacker1[i].toLowerCase() < hacker2[i].toLowerCase()){
console.log("The driver's name goes first");
break;
} else if (hacker1[i].toLowerCase() > hacker2[i].toLowerCase()){
console.log("Yo, the navigator goes first definitely");
break;
} else{
if (i === lengthName-1){
console.log(finalMessage);
}else{
Copy link
Contributor

Choose a reason for hiding this comment

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

Al último else parece que nunca entrará, quizás lo reorganizaría. Como elsesolo tendría que haber uno.

continue;
}
}
}
}


//Palindrome
let palindromeAlpha = '';

for (let i=0; i<palindromeString.length; i++){
if ((palindromeString[i]>= 'A' && palindromeString[i]<= 'Z')
||(palindromeString[i]>= 'a' && palindromeString[i]<= 'z')){
palindromeAlpha += palindromeString[i];
}
}

palindromeAlpha = palindromeAlpha.toLowerCase();

let reversedPalindrome = reverseString(palindromeAlpha);


if (palindromeAlpha === reversedPalindrome){
console.log ("Is palindrome");
}else{
console.log("Is not a palindrome");
}



// Lorem ipsum generator
12 changes: 12 additions & 0 deletions 12 starter-code/index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@

<html>
<head>
<script src="basic-algorithms.js"></script>
</head>

<body>

</body>


</html>
Morty Proxy This is a proxified and sanitized view of the page, visit original site.