. Day 3 - Challenge 3 - Armstrong Number Checker Skip to main content

Day 3 - Challenge 3 - Armstrong Number Checker

Exploring Armstrong Numbers: A Fascinating Mathematical Phenomenon

Have you ever encountered the term "Armstrong number" while diving into the world of programming or mathematics? If not, you're in for an intriguing journey of discovery! Armstrong numbers, also known as narcissistic numbers or pluperfect digital invariants, are a captivating mathematical phenomenon that can be explored through coding. In this blog post, we'll unravel the mystery behind Armstrong numbers and provide you with a JavaScript program to check whether a given number qualifies as an Armstrong number.

Understanding Armstrong Numbers

An Armstrong number (also referred to as a narcissistic number or pluperfect digital invariant) is a number that is equal to the sum of its own digits raised to the power of the number of digits. Let's break this down with an example:

Take the number 153. It has three digits. Now, let's compute the sum of its digits raised to the power of three (the number of digits):

1^3 + 5^3 + 3^3 = 1 + 125 + 27 = 153

As you can see, the sum of the digits raised to the power of three equals the original number itself, which makes 153 an Armstrong number.

Writing the JavaScript Program

Now that we understand what Armstrong numbers are, let's dive into writing a JavaScript program that checks whether a given number is an Armstrong number or not.


// Function to check if a number is an Armstrong number
function isArmstrongNumber(number) {
    const numStr = number.toString();
    const numDigits = numStr.length;
    let sum = 0;

    for (let digit of numStr) {
        sum += Math.pow(parseInt(digit), numDigits);
    }

    return sum === number;
}

// Test cases
const number1 = 153;
const number2 = 370;
const number3 = 371;
const number4 = 123;

console.log(`${number1} is an Armstrong number: ${isArmstrongNumber(number1)}`);
console.log(`${number2} is an Armstrong number: ${isArmstrongNumber(number2)}`);
console.log(`${number3} is an Armstrong number: ${isArmstrongNumber(number3)}`);
console.log(`${number4} is an Armstrong number: ${isArmstrongNumber(number4)}`);

In this program, the isArmstrongNumber function takes a number as an argument and checks whether it is an Armstrong number. It does so by converting the number to a string to extract its digits, calculating the sum of the digits raised to the power of the number of digits, and then comparing the sum with the original number.

Demo

Armstrong Number Checker

Enter a number to check if it's an Armstrong number:


Conclusion

Armstrong numbers offer a captivating glimpse into the world of number theory and programming. They showcase a unique property where the digits of a number interact in a fascinating way. By writing a JavaScript program to determine whether a given number is an Armstrong number, we've embarked on a journey that combines mathematical concepts with practical coding skills. So, the next time you encounter a number, consider exploring its Armstrong nature – you might just uncover a hidden gem of numerical intrigue!

Now write the same program in your favorite language in comment section. 

Other Challenges: 

  1. Day 1 Challenges
  2. Day 2 Challenges
  3. Day 3 Challenges

 

Comments

Popular posts from this blog

Create app in phonegap in windows

Phonegap (Cordova) is a tool that allows creating native mobile app using HTML, CSS and Javascript. This article shows you, how to create application and deploy them to various native mobile platforms using the cordova command-line interface (CLI). Install Cordova using CLI Follow these steps to install: Download and install Node.js . Following installation, you should be able to invoke node and npm on your command line. Install the cordova module using npm utility of Node.js. The cordova module will automatically be downloaded by the npm utility.   $ npm install -g cordova Create APP: Go to the directory where you maintain your source code, and run a command such as the following: using command. Create hello app: $ cordova create hello com.example.hello HelloWorld This command will create a folder ‘HelloWorld’. All subsequent commands need to be run within the project's directory, or any subdirectories. So go to in this folder ‘cd HelloWorld’. Add the pl...

Connecting to Socket in React Native app

Connecting to a socket in a React Native app requires the use of a socket library that supports React Native. One popular library is socket.io-client . Here are the steps to connect to a socket using socket.io-client in a React Native app: Install socket.io-client by running the following command in your project directory: npm install socket.io-client 2. Import the library in your code: import io from 'socket.io-client'; 3. Create a socket instance by calling the io function and passing in the URL of the socket server: const socket = io('http://example.com'); Replace http://example.com with the URL of your socket server. 4. Add event listeners to the socket instance to handle incoming events: socket.on('connect', () => { console.log('Connected to socket server'); }); socket.on('event', (data) => { console.log('Received data:', data); }); Replace event with the name ...

Know about the Web Socket and setup WebSocket in Javascript HTML page

  WebSockets is a protocol for providing full-duplex communication channels over a single TCP connection. It allows for real-time, two-way communication between a client and a server, which makes it ideal for web applications that require continuous updates from the server or that need to send frequent updates to the server. Here are some basic information about WebSockets: WebSockets are designed to work over a single TCP connection, which means that they are more efficient than other protocols like HTTP that require multiple connections for each request/response cycle. WebSockets use a persistent connection between the client and server, which allows for real-time communication without the need for frequent polling or long-polling requests. The WebSocket protocol uses a message-based model for sending and receiving data, which means that data is transmitted as a stream of messages rather than a series of HTTP requests and responses. WebSockets support binary data transmission, wh...