For working professionals
For fresh graduates
More
Explore C Tutorials: From Begi…
1. Introduction to C Tutorial
2. Addition of Two Numbers in C
3. Anagram Program in C
4. Armstrong Number in C
5. Array in C
6. Array of Pointers in C
7. Array of Structure in C
8. C Program to Find ASCII Value of a Character
9. Assignment Operator in C
10. Binary Search in C
11. Binary to Decimal in C
12. Bitwise Operators in C
13. Boolean in C
14. C Compiler for Mac
15. C Compiler for Windows
16. C Function Call Stack
17. C Language Download
18. Operators in C
19. C/C++ Preprocessors
20. C Program for Bubble Sort
21. C Program for Factorial
22. C Program for Prime Numbers
23. C Program for String Palindrome
24. C Program to Reverse a Number
25. Reverse a String in C
26. C string declaration
27. String Input Output Functions in C
28. Calculator Program in C
29. Call by Value and Call by Reference in C
30. Ceil Function in C
31. Coding Vs. Programming
32. Command Line Arguments in C/C++
33. Comments in C
34. Compilation process in C
35. Conditional Statements in C
36. Conditional operator in the C
37. Constant Pointer in C
38. Constants in C
39. Dangling Pointer in C
40. Data Structures in C
41. Data Types in C
42. Debugging C Program
43. Convert Decimal to Binary in C
44. Define And include in C
45. Difference Between Arguments And Parameters
46. Difference Between Compiler and Interpreter
47. Difference Between If Else and Switch
48. Do While Loop In C
49. Double In C
50. Dynamic Array in C
51. Dynamic Memory Allocation in C
52. Enumeration (or enum) in C
53. Evaluation of Arithmetic Expression
54. Factorial of A Number in C
55. Features of C Language
56. Fibonacci Series Program in C Using Recursion
57. File Handling in C
58. For Loop in C
59. Format Specifiers in C
60. Functions in C
61. Function Pointer in C
62. goto statement in C
63. C Hello World Program
64. Header Files in C
65. Heap Sort in C Program
66. Hello World Program in C
67. History of C Language
68. How to compile a C program in Linux
69. How to Find a Leap Year Using C Programming
70. Identifiers in C
71. If Else Statement in C
72. If Statement in C
73. Implementation of Queue Using Linked List
74. Increment and decrement operators in c
75. Input and Output Functions in C
76. How To Install C Language In Mac
77. Jump Statements in C
78. Lcm of Two Numbers in C
Now Reading
79. Length of an Array in C
80. Library Function in C
81. Linked list in C
82. Logical Operators in C
83. Macros in C
84. Matrix multiplication in C
85. Nested if else statement in C
86. Nested Loop in C
87. One Dimensional Array in C
88. Operator Precedence and Associativity in C
89. Overflow And Underflow in C
90. Palindrome Program in C
91. Pattern Programs in C
92. Pointer to Pointer in C
93. Pointers in C: A Comprehensive Tutorial
94. Pre-increment And Post-increment
95. Prime Number Program in C
96. Program for Linear Search in C
97. Pseudo-Code In C
98. Random Access Files in C
99. Random Number Generator in C
100. Recursion in C
101. Relational Operators in C
102. Simple interest program in C
103. Square Root in C
104. Stack in C
105. Stack Using Linked List in C
106. Static function in C
107. Stdio.h in C
108. Storage Classes in C
109. strcat() in C
110. Strcmp in C
111. Strcpy in C
112. String Comparison in C
113. String Functions in C
114. String Length in C
115. String Pointer in C
116. strlen() in C
117. Structures in C
118. Structure of C Program
119. Switch Case in C
120. C Ternary Operator
121. Tokens in C
122. Toupper Function in C
123. Transpose of a Matrix in C
124. Two Dimensional Array in C
125. Type Casting in C
126. Types of Error in C
127. Unary Operator in C
128. Use of C Language
129. User Defined Functions in C
130. What is Variables in C
131. Is C language case sensitive
132. Fibonacci Series in C
In computer science and mathematics, understanding and implementing the concept of finding the Least Common Multiple (LCM) of two numbers is fundamental. It plays a critical role in various computations and algorithms, making it a commonly addressed problem in coding interviews. This article elaborates on the concept of LCM and how to write an algorithm to find LCM of two numbers in C programming language.
The Least Common Multiple (LCM) of two or more integers is the smallest non-zero number that is a multiple of each of these integers. In other terms, it's the smallest common multiple of the integers. For instance, consider the numbers 4 and 5. The multiples of 4 are 4, 8, 12, 16, 20, 24, 28, 32, etc., and the multiples of 5 are 5, 10, 15, 20, 25, 30, 35, etc. The smallest number that appears in both lists of multiples is 20. Therefore, the LCM of 4 and 5 is 20.
To provide another example, consider the numbers 6 and 8. The multiples of 6 are 6, 12, 18, 24, 30, 36, 42, 48, etc., and the multiples of 8 are 8, 16, 24, 32, 40, 48, etc. The smallest common multiple of both is 24, so the LCM of 6 and 8 is 24.
The purpose of finding the LCM of two numbers is to determine the smallest positive integer that is divisible by both numbers without leaving a remainder. It is often used in various mathematical computations, such as simplifying fractions, solving equations involving fractions, and working with repeating patterns or cycles. In computer science and programming, the LCM is used in tasks like scheduling, time synchronisation, and optimisation problems.
There are multiple approaches to writing a program in the C programming language to calculate the LCM of two numbers. In this article, we will explore two commonly used methods:
Both methods have their advantages and can be implemented based on the specific requirements and constraints of the problem.
The algorithm to obtain the LCM of two numbers is as follows:
By calculating and using the GCD in the formula, the algorithm ensures that the LCM is obtained efficiently and accurately. The LCM is a useful value in various mathematical computations and can be applied in fields such as number theory, abstract algebra, and computer science.
Here's the pseudo-code representing the algorithm to find the LCM of two numbers:
1. Read num1, num2 from the user.
2. Calculate the GCD of num1 and num2 using the Euclidean algorithm and store it in gcd.
3. Calculate LCM using the formula: lcm = (num1 * num2) / gcd.
4. Print lcm as the LCM of num1 and num2.
This method utilises the concept of the Greatest Common Divisor (GCD) to find the LCM. The steps involved in this method are:
Example program to find LCM of two numbers using GCD
Given below is the program to find LCM of two numbers in C by using the Greatest Common Divisor (GCD) method:
#include <stdio.h> |
Time complexity of this method
The time complexity of this method is dependent on the time complexity of the GCD calculation algorithm. The Euclidean algorithm comprises a time complexity of O(log(min(num1, num2))), where num1 and num2 are the given numbers. Therefore, the overall time complexity of finding the LCM using GCD is also O(log(min(num1, num2))).
This method involves finding the prime factors of the two numbers and then computing the LCM by considering the highest power of each prime factor present in both numbers. The steps involved in this method are:
Example program to find LCM of two numbers using prime factorization
Given below is the program to find lcm of two numbers in C by using the prime factorization method:
#include <stdio.h> |
Time complexity of this method
The time complexity of finding the LCM using prime factorization is determined by the prime factorization algorithm. Assuming the numbers are not very large, the algorithm typically has a time complexity of O(sqrt(N)), where N is the maximum of the two numbers. Therefore, the overall time complexity of this method is O(sqrt(N)).
When it comes to a program to find lcm of two numbers in C, there are two commonly used methods: using the Greatest Common Divisor (GCD) and employing prime factorization. Let's compare these methods in terms of time complexity, applicability, and other factors:
Method | Time Complexity | Advantages | Disadvantages |
GCD Method | O(log(min(num1, num2))) | - Simple and straightforward | - Requires an additional GCD calculation |
- Efficient for most cases | |||
- Suitable for small and large numbers | |||
Prime Factorization | O(sqrt(N)) | - Provides prime factorization as a result | - Inefficient for extremely large numbers |
Method | - Suitable for situations requiring | ||
prime factorization |
The GCD method has a time complexity of O(log(min(num1, num2))), making it efficient for most cases. It is relatively simple to implement and suitable for small and large numbers. However, it requires an additional calculation of the GCD.
On the other hand, the prime factorization method has a time complexity of O(sqrt(N)), where N is the maximum of the two numbers. This method provides the prime factorization of the numbers as a byproduct, which can be useful in certain situations. However, it becomes inefficient when dealing with extremely large numbers.
Overall, the choice of method depends on the specific requirements and constraints of the problem at hand. In most cases, the GCD method is a popular and efficient choice. However, if prime factorization is needed or deals with small to moderate numbers, the prime factorization method may be preferred.
It's important to analyse the problem and consider factors like time complexity, number size, and other requirements before selecting the appropriate method for finding the LCM of two numbers.
Calculating the LCM of two numbers is an essential skill in programming and mathematics. In this article, we explored two popular methods, namely using the Greatest Common Divisor (GCD) and prime factorization, to find the LCM in the C programming language. Both methods offer efficient solutions for different scenarios.
By understanding these methods, you can confidently handle LCM calculations in your programs. To further enhance your programming skills and expand your knowledge, consider checking out Full Stack Software Development Bootcamp by upGrad. With guidance from industry veterans and immersive learning experiences, upGrad nurtures your development skills with the right programming knowledge, helping you bag exciting opportunities.
Mastering LCM calculations is just one step toward becoming a proficient programmer. Continuous learning and practice are key to unlocking your full potential!
Q: What is the LCM of three or more numbers?
The LCM of three or more numbers is the smallest positive integer divisible by each given number without leaving a remainder. It can be calculated by finding the LCM of two numbers at a time iteratively.
Q: Is the LCM of two numbers always greater than or equal to the numbers themselves?
Yes, the LCM of two numbers is always greater than or equal to the numbers themselves. This is because the LCM must be a multiple of both numbers and should be divisible by each of them.
Q: Can the LCM of two numbers be zero?
No, the LCM of the two figures cannot be zero. The LCM is defined as the smallest positive integer that should be divisible by both numbers. Therefore, it will always be greater than zero.
Q: Is it possible to find the LCM of negative numbers?
Yes, the concept of LCM can be applied to negative numbers as well. The absolute values of the numbers are used to calculate the LCM, and the signs of the input numbers determine the sign of the result.
Q: Can the LCM of two numbers be equal to one of the numbers?
Yes, the LCM of two numbers can be equal to one of the numbers. This occurs when one number is a multiple of the other, making the larger number itself the LCM.
Q: Are there any built-in functions in C to calculate the LCM?
No, C does not have a built-in function specifically for calculating the LCM. However, you can implement your own functions or use external libraries that provide LCM calculations.
Take a Free C Programming Quiz
Answer quick questions and assess your C programming knowledge
Author
Start Learning For Free
Explore Our Free Software Tutorials and Elevate your Career.
Talk to our experts. We are available 7 days a week, 9 AM to 12 AM (midnight)
Indian Nationals
1800 210 2020
Foreign Nationals
+918045604032
1.The above statistics depend on various factors and individual results may vary. Past performance is no guarantee of future results.
2.The student assumes full responsibility for all expenses associated with visas, travel, & related costs. upGrad does not provide any a.