mirror of
https://github.moeyy.xyz/https://github.com/TheAlgorithms/C.git
synced 2023-10-11 15:56:24 +08:00
Merge branch 'master' into problem_121
This commit is contained in:
commit
51e1c942da
11
README.md
11
README.md
@ -21,6 +21,8 @@ C
|
|||||||
- decimal_to_hexa
|
- decimal_to_hexa
|
||||||
- decimal_to_octal
|
- decimal_to_octal
|
||||||
- to_decimal
|
- to_decimal
|
||||||
|
- hexa_to_octal
|
||||||
|
|
||||||
|
|
||||||
## Data Structures
|
## Data Structures
|
||||||
- stack
|
- stack
|
||||||
@ -73,19 +75,20 @@ C
|
|||||||
|
|
||||||
|
|
||||||
## Misc
|
## Misc
|
||||||
|
- ArmstrongNumber
|
||||||
- Binning
|
- Binning
|
||||||
- Factorial
|
- Factorial
|
||||||
- Fibonacci
|
- Fibonacci
|
||||||
|
- Greatest Common Divisor
|
||||||
- isArmstrong
|
- isArmstrong
|
||||||
- LongestSubSequence
|
- LongestSubSequence
|
||||||
- palindrome
|
- palindrome
|
||||||
|
- prime factorization
|
||||||
- QUARTILE
|
- QUARTILE
|
||||||
- rselect
|
- rselect
|
||||||
- strongNumber
|
- strongNumber
|
||||||
- TowerOfHanoi
|
- Sudoku Solver
|
||||||
- Greatest Common Divisor
|
- TowerOfHanoi
|
||||||
- Sudoku Solver
|
|
||||||
- prime factorization
|
|
||||||
|
|
||||||
## Project Euler
|
## Project Euler
|
||||||
- Problem 1
|
- Problem 1
|
||||||
|
132
conversions/hexal_to_octal.c
Normal file
132
conversions/hexal_to_octal.c
Normal file
@ -0,0 +1,132 @@
|
|||||||
|
/* C program to convert Hexadecimal to Octal number system */
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
char hex[17];
|
||||||
|
long long octal, bin, place;
|
||||||
|
int i = 0, rem, val;
|
||||||
|
|
||||||
|
/* Input hexadecimal number from user */
|
||||||
|
printf("Enter any hexadecimal number: ");
|
||||||
|
gets(hex);
|
||||||
|
|
||||||
|
octal = 0ll;
|
||||||
|
bin = 0ll;
|
||||||
|
place = 0ll;
|
||||||
|
|
||||||
|
/* Hexadecimal to binary conversion */
|
||||||
|
for(i=0; hex[i]!='\0'; i++)
|
||||||
|
{
|
||||||
|
bin = bin * place;
|
||||||
|
|
||||||
|
switch(hex[i])
|
||||||
|
{
|
||||||
|
case '0':
|
||||||
|
bin += 0;
|
||||||
|
break;
|
||||||
|
case '1':
|
||||||
|
bin += 1;
|
||||||
|
break;
|
||||||
|
case '2':
|
||||||
|
bin += 10;
|
||||||
|
break;
|
||||||
|
case '3':
|
||||||
|
bin += 11;
|
||||||
|
break;
|
||||||
|
case '4':
|
||||||
|
bin += 100;
|
||||||
|
break;
|
||||||
|
case '5':
|
||||||
|
bin += 101;
|
||||||
|
break;
|
||||||
|
case '6':
|
||||||
|
bin += 110;
|
||||||
|
break;
|
||||||
|
case '7':
|
||||||
|
bin += 111;
|
||||||
|
break;
|
||||||
|
case '8':
|
||||||
|
bin += 1000;
|
||||||
|
break;
|
||||||
|
case '9':
|
||||||
|
bin += 1001;
|
||||||
|
break;
|
||||||
|
case 'a':
|
||||||
|
case 'A':
|
||||||
|
bin += 1010;
|
||||||
|
break;
|
||||||
|
case 'b':
|
||||||
|
case 'B':
|
||||||
|
bin += 1011;
|
||||||
|
break;
|
||||||
|
case 'c':
|
||||||
|
case 'C':
|
||||||
|
bin += 1100;
|
||||||
|
break;
|
||||||
|
case 'd':
|
||||||
|
case 'D':
|
||||||
|
bin += 1101;
|
||||||
|
break;
|
||||||
|
case 'e':
|
||||||
|
case 'E':
|
||||||
|
bin += 1110;
|
||||||
|
break;
|
||||||
|
case 'f':
|
||||||
|
case 'F':
|
||||||
|
bin += 1111;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
printf("Invalid hexadecimal input.");
|
||||||
|
}
|
||||||
|
|
||||||
|
place = 10000;
|
||||||
|
}
|
||||||
|
|
||||||
|
place = 1;
|
||||||
|
|
||||||
|
/* Binary to octal conversion */
|
||||||
|
while(bin > 0)
|
||||||
|
{
|
||||||
|
rem = bin % 1000;
|
||||||
|
|
||||||
|
switch(rem)
|
||||||
|
{
|
||||||
|
case 0:
|
||||||
|
val = 0;
|
||||||
|
break;
|
||||||
|
case 1:
|
||||||
|
val = 1;
|
||||||
|
break;
|
||||||
|
case 10:
|
||||||
|
val = 2;
|
||||||
|
break;
|
||||||
|
case 11:
|
||||||
|
val = 3;
|
||||||
|
break;
|
||||||
|
case 100:
|
||||||
|
val = 4;
|
||||||
|
break;
|
||||||
|
case 101:
|
||||||
|
val = 5;
|
||||||
|
break;
|
||||||
|
case 110:
|
||||||
|
val = 6;
|
||||||
|
break;
|
||||||
|
case 111:
|
||||||
|
val = 7;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
octal = (val * place) + octal;
|
||||||
|
bin /= 1000;
|
||||||
|
|
||||||
|
place *= 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
printf("Hexadecimal number = %s\n", hex);
|
||||||
|
printf("Octal number = %lld", octal);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
64
misc/ArmstrongNumber.c
Normal file
64
misc/ArmstrongNumber.c
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
//A number is called as Armstrong number if sum of cubes of digits of number is equal to the number itself.
|
||||||
|
// For Example 153 is an Armstrong number because 153 = 1³+5³+3³.
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
//Function to calculate x raised to the power y
|
||||||
|
int power(int x, unsigned int y)
|
||||||
|
{
|
||||||
|
if (y == 0)
|
||||||
|
return 1;
|
||||||
|
if (y % 2 == 0)
|
||||||
|
return power(x, y / 2) * power(x, y / 2);
|
||||||
|
return x * power(x, y / 2) * power(x, y / 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
//Function to calculate order of the number
|
||||||
|
int order(int x)
|
||||||
|
{
|
||||||
|
int n = 0;
|
||||||
|
while (x) {
|
||||||
|
n++;
|
||||||
|
x = x / 10;
|
||||||
|
}
|
||||||
|
return n;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Function to check whether the given number is
|
||||||
|
// Armstrong number or not
|
||||||
|
int isArmstrong(int x)
|
||||||
|
{
|
||||||
|
// Calling order function
|
||||||
|
int n = order(x);
|
||||||
|
int temp = x, sum = 0;
|
||||||
|
while (temp)
|
||||||
|
{
|
||||||
|
int r = temp % 10;
|
||||||
|
sum += power(r, n);
|
||||||
|
temp = temp / 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
// If satisfies Armstrong condition
|
||||||
|
if (sum == x)
|
||||||
|
return 1;
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
int x = 153;
|
||||||
|
if (isArmstrong(x) == 1)
|
||||||
|
printf("True\n");
|
||||||
|
else
|
||||||
|
printf("False\n");
|
||||||
|
|
||||||
|
x = 1253;
|
||||||
|
if (isArmstrong(x) == 1)
|
||||||
|
printf("True\n");
|
||||||
|
else
|
||||||
|
printf("False\n");
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user