I want to create a function that returns true if a number has consecutive digits or not,
example:
- if the input is 11, it will return true
- if the input is 21 it will return false
- if the input is 323 it will return false because even though we have 3 repeated, they are not consecutive
My solution right now is to transform the number into an array and loop through the number one by one, if the next number is equal to the current number then we just return true. But this has a complexity time of O(n) and I was wondering if anyone can come with a better solution.
Thank you
CodePudding user response:
There is an arguably better solution where you don't need to convert the number into a string or array of numbers/character. It works as follows:
- Initialize a variable
currto-1. - Run a loop
while num > 0and do the following:
next_curr = num % 10if next_curr == curr: return truecurr = next_currnum = num / 10(integer division)
- If the loop completes, return false.
This is a one pass O(log n) time complexity algorithm where n is the input number. The space complexity is O(1)
Note that while your algorithm was also O(log n) time complexity, it did 2 passes, and had a space complexity of O(log n) too.
I haven't written JS for some time now, but here's a possible implementation of the above algorithm in JS:
function sameAdjacentDigits(num) {
// to deal with negative numbers and
// avoid potential problems when using Math.floor later
num = Math.abs(num)
let curr = -1
while (num > 0) {
const nextCurr = num % 10
if (nextCurr == curr) return true
curr = nextCurr
num = Math.floor(num / 10)
}
return false
}
CodePudding user response:
Use some regex, and then check what was found via the matcher
numbers_match = /(00|11|22|33|44|55|66|77|88|99)/;
numbers_match.match("11")
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/match
CodePudding user response:
Inspired from @Tschallacka's answer:
let numbers = [11,21,323];
let result = numbers.map(n=>{
let test = n.toString().match(/(00|11|22|33|44|55|66|77|88|99)/);
return test != null;
})
console.log(result);
CodePudding user response:
Easiest way to execute this is by using regex. Not sure what would be effectiveness of algorithm, but solution could be
/(\d)\1/
CodePudding user response:
I would suggest following solution. Unfortunately not sure about time complexity, but I guess taking 2 numbers at a time should reduce execution time.
function hasConsecutive(input) {
const str = String(input);
let last;
for (let i = 0; i < str.length; i = 2) {
if (str[i] === last) return true;
if (str[i] === str[i 1]) return true;
last = str[i 1];
}
return false;
}
console.log(hasConsecutive(123455678));
CodePudding user response:
function has_consecutive_digits(num) {
for (let index = 0; num>0; index ) {
var lastdigit = num
var newnum = intval(num/10)
var beforelastdigit = newnum
if(beforelastdigit == lastdigit){
return true;
}
num = intval(num/10)
}
}
