Monday, November 2, 2015

Bonfire: Diff Two Arrays

Cracked this pretty easily i mean i started yesterday evening and was done today morning.
I used the consoler to debug using the last test case.

[1, "calf", 3, "piglet"], [7, "filly"] should return [1, "calf", 3, "piglet", 7, "filly"].


Here is my solution.
function diff(arr1, arr2) { var newArr = []; // Same, same; but different. var newarr2 = []; var newarr1 = []; for(i=0;i<arr2.length;i++) { if(arr1.indexOf(arr2[i])=== -1) { newarr1.push(arr2[i]); } console.log(newarr1); } for(i=0;i<arr1.length;i++){ if(arr2.indexOf(arr1[i])=== -1){ newarr2.push(arr1[i]); } console.log(newarr2); } var newarr = newarr1.concat(newarr2); return newarr; } diff([1, 2, 3, 5], [1, 2, 3, 4, 5]);

Bonfire:Sum of all Numbers in a Range.

I skipped directly to the Bonfires, since for Ziplines i think i need to brush up a little more on Bootstrap and HTML, CSS.
Planning to do the codeacademy tracks and become little more confident before i do the Ziplines.

This is my solution for sum of all numbers in a range.

Math.min() and Math.max() did not work when i passed the arr.
So googled it a bit and then passed elements of the array.

The sum of numbers in a range using Array.reduce() was already given in MDN example.
Solution:

function sumAll(arr) {
  var newarray = [];
  var minofarray = Math.min(arr[0],arr[1]);
  var maxofarray = Math.max(arr[0],arr[1]);
  for(i=minofarray;i<=maxofarray;i++){
    newarray.push(i);
    
  }
  var sumofarr = newarray.reduce(function(a, b) {
  return a + b;
});
  return sumofarr;
  
}

sumAll([1, 4]);

Wednesday, October 21, 2015

Bonfire : Check for Palindrome.

They mention here that we should remove all punctuation marks in the string.

Here are the strings  in the Bonfire test cases with punctuation marks.
"A man, a plan, a canal. Panama"
"My age is 0, 0 si ega ym."
"0_0 (: /-\ :) 0-0"


Used little bit of stackoverflow and MDN to understand .replace()
This is what I got:

Used a lot of console to debug each string and that really helped.



Code starts here

function palindrome(str) {
  
  // Good luck!
  //Removing punctuation marks and spaces in original string..
  var originalstring = str.replace(/[.,-\/#!$%\^&\*;:{}=\-_`~() " "]/gi,"").toLowerCase();
  var reversedstring = str.replace(/[.,-\/#!$%\^&\*;:{}=\-_`~() " "]/gi,"").toLowerCase().split("").reverse().join('');
  if(reversedstring === originalstring)
    {
  return true;
    }
  else
    {
      return false;
    }
}




palindrome("eye");






Factorial of Number Bonfire Solution

Used a while loop for this and it worked ok.

function factorialize(num) {
  factorial = 1;
  i = 1;
  while(i<=num)
    {
      factorial = factorial * i;
      i++;
    }
  return factorial;
}

factorialize(5);

Bonfire Reverse a String.

Was able to solve this using MDN examples and console.log() in chrome browser.
Solution:


function reverseString(str) {
 
  return str.split("").reverse().join('');
}

reverseString("hello");


Tuesday, October 20, 2015

Here goes the story for starting this blog.
1.There is not much going on at work and the next release for my project is slated to start Novemeber mid so I have a lot of time to kill, so  i thought why not learn D3.js.
I currently work with QlikView and feel extremely frustrated at some of the limitations for the visualization we can do with it.
Took a look at D3. js charts by Mike Bostock and woah, I'm like I want to be able to create them from scratch.

Also my coding skills have gotten little rusty over the past two years and hence learning D3 as a ruse to sharpen them.
Started with CodeAcademy but i felt its okay for learning syntax and basics for JS,HTML and CSS.

I came across freecodecamp after that now Im totally absorbed doing these Bonfire challenges.

Feeling really bad that I didnt get to do such stuff in my Engineering.
Also i started learning Python with Coursera's Rice University Course but I get distracted really easily.

FreecodeCamp is working out good so far because i like to learn by doing stuff.

On the work front I still have loads to learn, but need to make time for it.

Bonfire : Where do I Belong

function where(arr, num) {
  // Find my place in this sorted array.
   arr.sort(function(a, b) {
  return a - b;
});
 
//at this point the array is all sorted
 //the below function gets the maxnumber in the array
  function maxnumberinarray( array ){
    return Math.max.apply( Math, array );
};
  if(num>maxnumberinarray(arr)){
    return arr.length;
  }
  var pos = 0;
  for(i=0;i<arr.length;i++)
    {
      if(arr[i]<num){
        pos = i+1;
      }
      else {
      return pos;
      }
    }
}

where([10, 20, 30, 40, 50], 35)