C Foundation

What is C? C Compiler Installation C Extensions C Compiler C Interpreter C Program Structure

C Basics

C Keywords C Data Types C Identifiers C Variables C Constant C Escape Sequences C Constant and Volatile C Typecast

Operators

What is Operator C Comma Operator C Arithmetic Operators C Relational Operators C Logical Operators C Bitwise Operators C Conditional Operators C : : Operator C Operator Priority

Basic IO's

Basic IO's C Formatted Functions C Unformatted Functions C Common Functions

Control Statements

What is Control Statement C if Statement C if else Statement C Nested if Statement C Else if Statement C Break Statement C Continue Statement C Switch Statement C Goto Statement

Looping

What is Control Loop C for Loop C Nested for Loop C while Loop C Nested while Loop C do while Loop C Nested do while loop

Functions

What is Function C User Defined Functions C Recursion C Passing Parameters

Scope

Scope C Local Scope C Global Scope

Storage Classes

What is Storage Class C Auto C Extern C Static C Register

Array

What is Array C One Dimensional Array C Two Dimensional Array C Multi Dimensional Array C Arrays Of Strings

String

What is String C String Functions

Pointer

What is Pointer C Pointers Arithmetic C Pointer to Pointer C Pointers and Arrays C Pointers and Strings C Pointer to Functions Void Pointers Null Pointers C Null and Void Pointer

Structure

What is Structure C Struct within Struct C Array within Structure C Pointer to Structure C Structure and Function C Enum C Bitfield Structure C Type def

Union

What is Union

Files

What is File C read a file C write a file C File Handling C Error Handling C Low Level Disk I/O C Other file functions

Memory Allocation

What is Memory Allocation C Malloc() C Calloc() C Free() C Realloc() C Coreleft()

C Reference

All ASCII Code Basic C Questions

C Interview

C Interview Sets All Star Patterns All Number Patterns All Alphabet Patterns All Series Patterns
The ones who are crazy enough to think they can change the world are the ones who do.
- Steve Jobs

C Division Without Using Divide Operator

division without using division operator

In my college days my programming friend makes a rigorous challenge with me. He asked me to divide two numbers without using division operator, it's sounds poor right. Division without using division operator is it possible for you?

You being a programmer, Impossible is nothing more than having two cups of coffee instead of a coffee, lets code a C program to divide two numbers without using division operator.

C Program - Without Using Division Operator

c-without-division-operator.c
#include <stdio.h>
int division(int, int);
int main()
{
int num1, num2;
printf("\nEnter any two integers : ");
scanf("%d %d ", &num1, &num2);
printf("Result is %d ", division(num1, num2));
return 0;
}
int division(int num1, int num2)
{
int temp = 1, quotient = 0;
while (num2 <= num1)
{
num2 <<= 1;
temp <<= 1;
}
while (temp > 1)
{
num2 >>= 1;
temp >>= 1;
if(num1 >= num2)
{
num1 -= num2;
quotient += temp;
}
}
return quotient;
}
Enter any two integers : 4 2
Result is : 2

Note:

Lets look closely in first while-loop inside division function.

Iteration 1: while(num2 <= num1);. i.e) while(2 <= 4)

num2 <<= 1

  • num2 = num2 << 1;
  • num2 = 2 << 1
  • num2 = 4;

temp <<= 1

  • temp = temp << 1;
  • temp = 1 << 1
  • temp = 2;

Iteration 2: while(num2 <= num1);. i.e) while(4 <= 4)

num2 <<= 1

  • num2 = num2 << 1;
  • num2 = 4 << 1
  • num2 = 8;

temp <<= 1

  • temp = temp << 1;
  • temp = 2 << 1
  • temp = 4;

Now looking closely in second while-loop inside division function Iteration 1: while(temp > 1) i.e) while(4 > 1)

num2 >>= 1

  • num2 = num2 >> 1
  • num2 = 1000 >> 1
  • num2 = 0100
  • num2 = 4;

temp >>= 1

  • temp = temp >> 1
  • temp = 0100 >> 1
  • temp = 0010
  • temp = 2;

if(num1 >= num2)

  • num1 -= num2;
  • num1 = num1 - num2;
  • num1 = 4 - 4;
  • num1 = 0;

quotient += temp;

  • quotient = quotient + temp;
  • quotient = 2;

Iteration 3: while( temp > 1);. ie) while(2 > 1) condition true

num2 >>= 1;

  • num2 = num2 >> 1;
  • num2 = 4 >> 1;
  • num2 = 2;

temp >>= 1;

  • temp = temp >>1;
  • temp = 2 >>1;
  • temp = 1;

if(num1 >= num2)

Condition fails, thus value inside quotient i.e) 2 is outputted.

Report Us

We may make mistakes(spelling, program bug, typing mistake and etc.), So we have this container to collect mistakes. We highly respect your findings.

Report