Check if nth
Bit in a 32 bit Integer is Set or not
#include
#include
int result,position;
int n_bit_position(int x,int position);
void main()
{
unsigned int number;
clrscr();
printf("Enter the unsigned integer:\n");
scanf("%d", &number);
printf("Enter position\n");
scanf("%d", &position);
n_bit_position(i, position);
if (result & 1)
printf("Yes\n");
else
printf("No\n");
}
int
n_bit_position(int number,int position)
{
result = (number>>(position));
getch();
}
Output
Enter the unsigned
integer:
101
Enter position
4
No
Enter the unsigned
integer:
113
Enter position
4
Yes
Check if a given Integer is a Power of 2 without using Bitwise
#include
#include
int power_of_2(unsigned int);
int b[32] = {0}, j = 0, n, i, count = 0;
void main()
{
unsigned int num;
clrscr();
printf("Enter value\n");
scanf("%d", &num);
power_of_2(num);
if (count == 1)
printf("Yes\n");
else
printf("No\n");
}
int power_of_2(unsigned int num)
{
while (num != 0)
{
n = num % 2;
if (n == 1)
count++;
num = num / 2;
}
getch();
}
Output
Enter value
128
Yes
Enter value
126
No
Perform Binary Addition of Strings and Print it
#include
#include
#include
char s1[10], s2[10], s3[10];
int i, k;
char carry = '0';
void binary_add(char *,char *);
void main()
{
printf("Enter string1\n");
scanf(" %[^\n]s", s1);
printf("Enter string2\n");
scanf(" %[^\n]s", s2);
binary_add(s1, s2);
printf("Binary addition of number is\n");
if (carry == '1')
{
s3[i] = '1';
for (i = 1;i <= k + 1;i++)
printf("%c", s3[i]);
printf("\n");
}
else
{
for (i = 1;i <= k + 1;i++)
printf("%c", s3[i]);
printf("\n");
}
}
void binary_add(char *s1, char *s2)
{
char *p1, *p2;
p1 = s1;
p2 = s2;
k = strlen(s1);
for (;*p1 != '\0' && *p2 != '\0';p1++, p2++);
p1--;
p2--;
s3[k+1] = '\0';
for (i = k + 1;i >= 1;i--, p1--, p2--)
{
if (*p1 == '0' && *p2 == '0'&& carry == '0')
{
s3[i] = (*p1 ^ *p2) ^ carry;
carry = '0';
}
else if (*p1 == '0' && *p2 == '0' && carry == '1')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '0';
}
else if (*p1 == '0' && *p2 == '1' && carry == '0')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '0';
}
else if (*p1 == '0' && *p2 == '1' && carry == '1')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '1';
}
else if (*p1 == '1' && *p2 == '0' && carry == '0')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '0';
}
else if (*p1 == '1' && *p2 == '0' && carry == '1')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '1';
}
else if (*p1 == '1' && *p2 == '1' && carry == '0')
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '1';
}
else
{
s3[i] = (*p1 ^ *p2)^ carry;
carry = '1';
}
}
getch();
}
Output
Enter string1
00010001
Enter string2
00010010
Binary addition of number is
000100011
Check if a given Bit Position is set to One or not
#include
#include
void main()
{
unsigned int number;
int result, position;
clrscr();
printf("Enter the unsigned integer:\n");
scanf("%d", &number);
printf("enter position to be searched\n");
scanf("%d", &position);
result = (number >> (position));
if (result & 1)
printf("True\n");
else
printf("FalsE\n");
getch();
}
Output
Enter the unsigned integer:
128
Enter position to be searched
7
True
No comments:
Post a Comment