Thursday, 28 December 2017

We Will Be Back Soon....




Yes, you read it right, we will be back soon with more content, more questions, and even more answers.


First of all we would like to thank you all who have been to the blog and made it what it is right now.

Secondly we would request you to ask any question related to competitive programming or any queries you have in the comments section of this or any other post you feel like.

Thirdly if you don't find any question from the elab platform here and want it to be added all you need to do is this :

  1. Take a screenshot of the question and the sample test cases
  2. Upload it to Google Drive
  3. Send the link in the comments section of any post
The question will be attended to soon and an answer will be uploaded to the blog ASAP.

Finally we would like to thank you again for making 2017 a great year .

Wishing you a Happy New Year 2018

programmers@wttech

Saturday, 29 July 2017

Radius of a Circle

QUESTION DESCRIPTION

Madhan is handling mathematics to 8th grade. He taught area and perimeter of geometric shapes to his students. He thought to give a test based on triangle and circles.The task is to calculate radius of the circle that is inscribed in triangle given the three sides of the triangle. He has set 20 questions and he is tired of preparing answer keys.Write a program to find the radius of the circle inscribed in a triangle.

Input and Output Format :
Input consists of three integers a, b and c. The three integer
corresponds to three sides of a triangle.

TEST CASE 1


INPUT

3 4 5

OUTPUT

The radius of the circle is=1.00


EXPLANATION :

The code requires you to output the radius of a circle inscribed inside a triangle.
The input given is the three sides of the triangle and the output required is the radius of the circle that is inscribed inside the triangle in the specified format.

There are two basic geometric formula that can be used to get the desired result :
> r^2=(s-a)*(s-b)*(s-c)/s
> where s=(a+b+c)/2

The other method is  another format of the same formula that has been used above :

> r=((a+b-c)*(a+c-b)*(b+c-a))/2

ALGORITHM :
  • Accept the inputs in the program (int a,b,c)
  • Using either of the formulas calculate the value of the radius 
    • To calculate the square root of the equation the sqrt function is used, the header <math.h> needs to be imported to use the sqrt function.
  •  Print the radius with the desired tag "The radius of the circle is="

SOLUTION : (Please use this as reference only)

CODE

Sunday, 2 April 2017

No of Distinct Elements In An Unsorted Array

QUESTION DESCRIPTION

Write a program to find the number of distinct elements in a unsorted array. [Do it without sorting the array]

Input Format:
Input consists of n+1 integers. The first integer corresponds to n, the number of elements in the array. The next n integers correspond to the elements in the array. Assume that the maximum value of n is 15.

Output Format:
Output consists of a single integer which corresponds to the number of distinct elements in the array.


TEST CASE 1
 
INPUT

5
3 2 3 780 90

OUTPUT

4

TEST CASE 2

INPUT

10
1000 1001 1002 1003 2006 3005 2009 4006 5000 9000

OUTPUT

10


EXPLANATION :

The code requires you to count the number of unique elements present in an array .

ALGORITHM : 

  • Accept the number of elements in the array ( n )
  • Run a loop to accept the numbers into the array ( scanf("%d",&arr[i]) )
  • Remove the redundant elements by checking each number with the rest of the array elements and replacing all other occourances with -999999990
  • After removing the redundant elements count all elements other than -999999990 
  • Print the result.

SOLUTION : (Please use this as reference only)

CODE

Monday, 27 March 2017

Array Range

QUESTION DESCRIPTION 

Write a program to find the range of the elements in the array.

Range of an array is the difference between the maximum and minimum element in an array,

Input and Output Format:

Input consists of n+1 integers where n corresponds to the number of elements in the array.

The first integer corresponds to n and the next n integers correspond to the elements in the array.

Output consists of an integer which corresponds to the range of the array.

Assume that the maximum number of elements in the array is 20.

Refer sample input and output for formatting specifications.

All text in bold corresponds to input and the rest corresponds to output.


TEST CASE 1

INPUT

5
1 2 4 3 5

OUTPUT

The range of the array is:4


EXPLANATION : 

The code requires you find the range of the elements of the array ( range : max element - min element )

ALGORITHM : 

  • Accept the number of elements from user ( n )
  • Accept the numbers from the user 
  • Check for the largest and smallest number ( arr[i] > max , arr[i] < min )
  • Calculate the range ( max-min )
  • Print the result with appropriate message

SOLUTION : (Please use this as reference only)

CODE


SYMMETRIC MATRIX

QUESTION DESCRIPTION

A symmetric matrix is a square matrix that is equal to its transpose.
Write a C program to find whether a given matrix is a square matrix or not.
Input Format:

The input consists of (m*n+2) integers. The first integer corresponds to m, the number of rows in the matrix and the second integer corresponds to n, the number of columns in the matrix. The remaining integers correspond to the elements in the matrix. The elements are read in rowwise order, first row first, then second row and so on. Assume that the maximum value of m and n is 10


TEST CASE 1

INPUT

3 3
1 2 3
4 5 6
7 8 9

OUTPUT

Not Symmetric


TEST CASE 2

INPUT

3 3
3 1 1
1 3 1
1 1 5

OUTPUT

Symmetric


EXPLANATION : 

The code requires you to check whether a given square matrix is a symmetric matrix or not Symmetric Matrix )

ALGORITHM : 

  • Accept the number of rows and columns from user ( n,m )
  • Check if array is a square matrix ( n==m )
  • Accept the elements of the array using scanf ( arr[][] )
  • Check if array elements are symmetric ( arr[i][j]==arr[j][i] )
  • If the condition fails , change flag to 0 and jump out of the 2 loops ( goto here )
  • If the array is not a square change flag to 0
  • After the loop check if flag is 0 or 1  ( flag==1 )
  • Print the appropriate result for the two cases

SOLUTION : (Please use this as reference only)

CODE

UNIFORMITY MATRIX

QUESTION DESCRIPTION

Uniformity matrix is a matrix in which all the elements in the matrix are either completely even or completely odd.

Write a C program to find whether a given matrix is a uniformity matrix or not.

Input Format:

The input consists of (n*n+1) integers. The first integer corresponds to the number of rows/columns in the matrix. The remaining integers correspond to the elements in the matrix. The elements are read in rowwise order, first row first, then second row and so on. Assume that the maximum value of m and n is 5.

Output Format:

Print yes if it is a uniformity matrix. Print no if it is not a uniformity matrix.


TEST CASE 1

INPUT

2
4 5
5 4

OUTPUT

no


EXPLANATION : 

The code requires you to check whether a given square matrix is a uniformity matrix or not ( Uniformity matrix is a matrix in which all the elements in the matrix are either completely even or completely odd )

ALGORITHM : 

  • Accept the number of rows and columns from user ( n )
  • Accept the elements of the array using scanf ( arr[][] )
  • Simultaneously calculate if the number being input is even ( arr[i][j]%2==0 )
  • If the number is even increase counter by 1 ( cnt++ )
  • After the loop check if counter is equal to array size ( if all elements are even ) or equal to zero ( if all elements are odd ) ( cnt==n*n||cnt==0 )
  • Print the appropriate result for the two cases

SOLUTION : (Please use this as reference only)


Magic Square

QUESTION DESCRIPTION

A magic square is an arrangement of numbers (usually integers) in a square grid, where the numbers in each row, and in each column, and the numbers in the forward and backward main diagonals, all add up to the same number

Write a program to find whether a given matrix is a magic square or not.

Input Format:

The input consists of (n*n+1) integers. The first integer corresponds to the number of rows/columns in the matrix. The remaining integers correspond to the elements in the matrix. The elements are read in rowwise order, first row first, then second row and so on. Assume that the maximum value of m and n is 5.

Output Format:
Print yes if it is a magic square. Print no if it is not a magic square 


TEST CASE 1

INPUT

2
4 5
5 4

OUTPUT

no


EXPLANATION : 

The code requires you to check whether a given square matrix is a magic square or notMagic Square )

ALGORITHM : 

  • Accept the number of rows and columns from user ( n )
  • Accept the elements of the array using scanf ( arr[][] )
  • Simultaneously calculate the sum of leading diagonal ( sum+=arr[i][i] , when i ==j
  • Calculate the sum of rows ( sum1+=arr[i][j] )
  • Calculate the sum of columns ( sum2+=arr[j][i] )
  • Calculate the sum of non leading diagonal ( sum+=arr[i][i] , when i+j+1 =n )
  • Check if all the sums are equal ( sum==sum3 and flag==1 )
  • Print the appropriate result

SOLUTION : (Please use this as reference only)


Sunday, 26 February 2017

IO 8

QUESTION DESCRIPTION :


Write a program to find the largest of three numbers using ternary operator

Input and Output Format:

Refer sample input and output for formatting specification.

All float values are displayed correct to 2 decimal places.

All text in bold corresponds to input and the rest corresponds to output.


TEST CASE 1


INPUT

4 5 6

OUTPUT

The biggest number is:6


TEST CASE 2


INPUT

99 9999 99999

OUTPUT

The biggest number is:99999


EXPLANATION : 

The code requires you to print the largest among the 3 numbers but you need to use the ternary operator ( Ternary Operation )

ALGORITHM : 

  • Accept the numbers from the user ( a,b,c )
  • Check the largest number using ternary operator
  • Print the largest number with the appropriate message

SOLUTION : (Please use this as reference only)

CODE


Wednesday, 22 February 2017

PRINT 2

QUESTION DESCRIPTION :

Write a C program to print all numbers between a and b ( a and b inclusive) using a while loop.

Input format:

Input consists of 2 integers. The first integer corresponds to a and the second integer corresponds to b . Assume a>=b.

Output format:

Refer sample input and output for formatting specifications.


TEST CASE 1

INPUT

10
4

OUTPUT

10
9
8
7
6
5
4


TEST CASE 2


INPUT

5
4

OUTPUT

5
4


EXPLANATION :
According to this program we need enter two integer value and we have print a series of numbers with the help of simple while looping statement. ( While loop )


ALGORITHM : 

  • Input the two numbers from the user ( a,b )
  • Run a while loop with the condition a>b ( while (a>b) )
  • Print the value of "a" variable 
  • Reduce the value of a by 1 ( a-- )
SOLUTION : (Please use this as reference only)

CODE

Lab seating Arrangement

QUESTION DESCRIPTION :

There are 2 Programming Labs . Each with a seating capacity of 90. There are 240 students with registration numbers from 1 to 240. All 240 students cannot be accommodated in the labs at the same time. It has been decided to conduct theory class for 60 students every week. It has been planned to conduct theory classes for all students with register number being a multiple of 4. Students with registration number from to 1 to 120 with registration number not a multiple of 4 need to be seated in programming lab1 and students with registration numbers from 121 to 240 with registration numbers not a multiple of 4 need to be seated in programming lab II.

Given the registration number of student, write a C program to specify the lab or hall in which student need to be seated.

Input Format:

Input consists of 1 integer which corresponds to the registration number of the student.

Output format:

Output consists of string "Lab 1" or "Lab 2" or "Theory session " or ?Incorrect Register Number?

Refer sample input and output for further formatting specifications.


TEST CASE 1
 
INPUT
16
OUTPUT

Theory session

TEST CASE 2

INPUT
239
OUTPUT

Lab 2


EXPLANATION :

The code requires you to input a number and output the class room of the person , i.e. either Theory session or Lab 1 or Lab 2 .

The input will be an integer corresponding to the Registration Number of the student.

The output is the session that the person has to attend.


ALGORITHM : 

  • Accept the number from the user ( a )
  • Check if the person has to attend theory session ( a%4==0&&a!=0 ) 
  • Print Theory session if the case is true .
  • If it is false , check for Lab 1 ( a<120&&a>=1 )
  • Print Lab 1 if the case is true
  • If it is false , check for Lab 2 ( a<240&&a>120 )
  • Print Lab 1 if the case is true
  • If all other cases are false check for wrong register number ( a>240||a<1 )
  • Print Incorrect Register Number if the case is true
SOLUTION : (Please use this as reference only)
CODE

In/out

QUESTION DESCRIPTION :

Ms.Kirthiga, the faculty handling programming lab for you is very strict. Your seniors have told you that she will not allow you to enter the weeks lab if you have not completed atleast half the number of problems given last week. Many of you didnt understand this statement and so they requested the good programmers from your batch to write a c program to find whether a student will be allowed into a week lab given the number of problems given last week and the number of problem solved by the students in that week.

Input format:
Input consists of 2 integers. The First integer corresponds to the number of problems given and the second integer corresponds to the number of problems solved.

Output format:
Output consists of the string "IN" or "OUT"
Refer sample input and output for further formatting specifications.


TEST CASE 1

INPUT

8
3

OUTPUT

OUT


EXPLANATION :

The code requires you to check weather a person is eligible to enter the LAB or not.

The entry criteria is that a person should have completed at least 50% or half of the problems given to them last week.

The input consists of 2 numbers , first one is the number of problems given to the person last week and second is the number of problems done by him/her.

Check if the person has done 1/2 or more problems and print IN or OUT according to the condition.

ALGORITHM : 

  • Input two integers from the user ( a,b )
  • Check if questions done is more than 1/2 of the questions given (  b>=(int)(a/2) )
  • If the condition is true ,print IN
  • Otherwise print OUT

SOLUTION : (Please use this as reference only)
CODE
 

A Task

QUESTION DESCRIPTION :

A task is given to 3 persons to complete it within a particular time. If the person exceeds the time limit he will be disqualified . Only those who complete it within the given time limit is qualified. Among the qualified persons. the person who complete the task first will be rewarded.Write a C program to find the person who is rewarded.

Input Format:

First Input corresponds to the time limit for the task in hours . Second, third and fourth input corresponds to the number of hours taken by the first, second and third persons respectively to complete the task.

Output format:

Display the person who completes first.


TEST CASE 1
 
INPUT

10 5 4 7

OUTPUT

Second person wins!!


TEST CASE 2

INPUT

4 9 6 7

OUTPUT

No person wins!!


EXPLANATION :

The code requires you check for the time taken by 3 people to complete a task and find out who won the competition by comparing the time taken by them ( the person with the least time wins ) . But if the best time is > than the disqualification time , then all the 3 people are disqualified .

The input format is 4 integers representing the time limit and the time taken by the 3 people to complete the tasks.


ALGORITHM :

  • Input 4 integers from the user ( r , a , b , c )
  • Check weather first person has won ( r>a&&a<b&&a<c )
  • Check weather second person has won ( r>b&&b<a&&b<c )
  • Check weather third person has won ( r>c&&c<a&&c<b )
  • According to the winner , print the correct output
  • If no one wins ( all conditions fail ) , print No person wins!!
# Note :  r is the max time alloted , a,b,c are the values of the time taken by person 1,2,3 respectively
SOLUTION : (Please use this as reference only)
CODE
 

Class Representative

QUESTION DESCRIPTION :

A student is eligible to be a class representative if his or her attendance % and marks is greater that 90% and he or she doesnt have any arrears. Given the attendance % ,mark % and number of arrears, write a C program to determine whether a student is eligible to be a Class Representative or not.

Input format:
Input consists of 2 float and an integer. The first float corresponds to the attendance % and the second float corresponds to the percentage of marks. The third input is an integer which corresponds to the number of arrears.

Output format :
Output consists of the string "Eligible " or "Not Eligible"
Refer sample input and output for further formatting specifications.


TEST CASE 1

INPUT

90.1
90.1
0 

OUTPUT

Eligible
 

TEST CASE 2

INPUT

90.0
90.0
0

OUTPUT

Not Eligible


EXPLANATION :

The code requires you to accept 2 float inputs corresponding to attendance % , marks % and  an integer corresponding to the number of arrears he/she has in exams.

The result will be Eligible or Not Eligible , depending on the conditions mentioned above ( attendance and exam % >90 and arrears=0  , then the person is eligible ) 


ALGORITHM :

  • Accept 3 numbers from the user , first two are float and the last one is integer ( a,m,ar )
  • Check for eligibility for being the Class representative ( (a>90.0)&&(m>90.0)&&ar==0 )
  • If the above test case is true , print Eligible
  • If the above test case is not true , print Not Eligible
#Caution : Person with 90.0 % is not eligible , %age should be grater than 90.0
 
SOLUTION : (Please use this as reference only)
 
CODE
 

Tuesday, 21 February 2017

Splitting into Teams

QUESTION DESCRIPTION :

During the Physical Education hour, PT sir has decided to conduct some team games. He wants to split the students in the class into equal sized teams. In some cases, there may be some students who are left out from teams and he wanted to use the left out students to assist him in conducting the team games.
For instance, if there are 50 students in the class and if the class has to be divided into 7 equal sized teams, 7 students will be there in each team and 1 student will be left out.
PT sir asks your help to automate this team splitting task. Can you please help him out?

Input Format:
Input consists of 2 integers. The first integer corresponds to the number of students in the class and the second integer corresponds to the number of teams.


TEST CASE 1

INPUT

60
8

OUTPUT

The number of students in each team is 7 and left out is 4


TEST CASE 2

INPUT

100
22

OUTPUT

The number of students in each team is 4 and left out is 12


EXPLANATION :

The code is a basic mathematics problem which uses the divide and modulo operation , to calculate the number of people in each group and the number of people left out after equal division in groups.

For counting the number of people in each group , we use the / operation and for the people left out we use the % operation
 
The input format is two integers , first one is the number of students in total and the second one is the number of teams to be formed


ALGORITHM : 

  • Take two inputs from the user , for number of students and teams ( a,b )
  • Calculate the number of people in each team ( a/b )
  • Calculate the number of people left out ( a%b )
  • Print the result with appropriate message
 
SOLUTION : (Please use this as reference only)

CODE

Calculating Gain Percentage

QUESTION DESCRIPTION :

Vikram buys an old scooter for Rs. A and spends Rs. B on its repairs. If he sells the scooter for Rs. C , what is his gain %?
Write a C program to compute the gain %.
Input Format:
The first input is an integer which corresponds to A. The second input is an integer which corresponds to B. The third input is a float which corresponds to selling price



TEST CASE 1

INPUT

4700
800
5800

OUTPUT

The gain percentage is=5.45


EXPLANATION :

The code requires you to accept 3 integers from the user , which correspond to Cost Price , Repair Price and Selling Price respectively and then find the gain/profit percentage for the given input.

FORMULA :

Gain % = (( Selling Price - ( Cost Price + Repair Cost )) / (Cost Price + Repair Cost ) )*100


ALGORITHM : 

  • Accept 3 integers from the user ( a,b,c )
  • Calculate the gain % by using the given formula ( ((c-a-b)*1.0/(a+b))*100 ) ( Multiplying by 1.0 converts it to float ( can be used instead of type casting ) )
  • Print the result with the required message

SOLUTION : (Please use this as reference only)

CODE

Finding bitwise AND of two numbers

QUESTION DESCRIPTION :

Write a program to find the bitwise AND of two decimal numbers.
An AND gate reads 2 input either 0 or 1 and outputs 1 iff both the inputs are 1. Similarly write a program to read two decimal numbers and finds AND of two numbers.
EXAMPLE :
(3)10 = (011)2
(5)10 = (101)2
AND of 3 and 4 is :
(1)10 = (001)2
TEST CASE 1

INPUT

12 23

OUTPUT

Bitwise AND of 12 and 23 is:4


EXPLANATION :

The code requires you to accept two inputs from the user and perform the AND & operation ( Bitwise Operators ) on them and print the result.


ALGORITHM : 

  • Input two integers from the user ( a,b )
  • Calculate the bitwise AND ( a&b )
  • Print the result with the required messages. 

SOLUTION : (Please use this as reference only)
CODE

Finding OR of two numbers

QUESTION DESCRIPTION :

Write a program to find the bitwise OR of two decimal numbers.
An OR gate reads 2 input either 0 or 1 and outputs 0 iff both the inputs are 0 else 1. Similarly write a program to read two decimal numbers and finds OR of two numbers.

EXAMPLE :
(3) 10 = (011) 2
(5) 10 = (101) 2
OR of 3 and 4 is :
(7) 10 = (111) 2


TEST CASE 1

INPUT

12
23

OUTPUT

Bitwise OR of 12 and 23 is=31


EXPLANATION :

The code requires you to accept two inputs from the user and perform the OR | operation ( Bitwise Operators ) on them and print the result


ALGORITHM : 

  • Input two integers from the user ( a,b )
  • Calculate the bitwise OR ( a|b )
  • Print the result with the required messages. 

SOLUTION : (Please use this as reference only)

CODE

FOUR SEASONERS

QUESTION DESCRIPTION :

Dinesh also joined the group of 3 idiots and now their group is called Four Seasoners. Meanwhile, Binoy has moved to a new house in the same locality. Now the houses of Ajay, Binoy and Chandru are in the located in the shape of a triangle. Dinesh also has moved to a house in the same locality. When Ajay asked Dinesh about the location of his house , Dinesh said that his house is equidistant from the houses of the other 3. Though Ajay was good in Mathematics, he was puzzled. Can you please help Ajay out?

Given the 3 vertices {(x1,y1), (x2,y2) and (x3,y3)} of a triangle, write a C program to determine the point which is equidistant from all the 3 vertices.

Input Format:
Input consists of 6 integers. The first integer corresponds to x1 . The second integer corresponds to y1. The third and fourth integers correspond to x2 and y2 respectively.
The fifth and sixth integers correspond to x3 and y3 respectively.


TEST CASE 1

INPUT

2 4
10 15
5 8

OUTPUT

Dinesh house is located at (5.7,9.0)


EXPLANATION :

The code requires you to take input , 3 set of coordinates ( x,y ) , for three friends of Dinesh and calculate the coordinates of his house such that is it at equal distance form all the three houses.
If we consider the 3 houses to be the three vertices of the triangle , then the point at equal distance of  all of them is the circumcentre Circumcenter ). So we have to calculate the circumcenter of the triangle , whose coordinates have been given.


QUESTION ISSUES :

The circumcenter of the triangle in the given example ( sample I/O ) is ( -230.5 , 181.5 ) , but the output given,  corresponds to the centroid of the given triangle. So either the input or output needs to be changed or the question description. For the sake of getting the correct output , I will calculate the centroid instead of the circumcenter. ( The triangle should be an equilateral triangle for circumcenter and centroid to coincide ( no such condition is given ) )


ALGORITHM :

  • Take 6 inputs from the user corresponding to the x,y coordinates of the three houses ( x1,y1,x2,y2,x3,y3 )
  • Calculate the centroid of the triangle ( (x1+x2+x3)/3.0 , (y1+y2+y3)/3.0 )
  • Print the result with the required message.
 
 SOLUTION : (Please use this as reference only)

CODE

Grade The Steel

QUESTION DESCRIPTION : 

A certain grade of steel is graded according to the following conditions.

Hardness must be greater than 50.
Carbon content must be less than 0.7.
Tensile strength must be greater than 5600.
The grades are as follows:

Grade is 10 if all three conditions are met.

Grade is 9 if conditions (i) and (ii) are met.
Grade is 8 if conditions (ii) and (iii) are met.
Grade is 7 if conditions (i) and (iii) are met.
Grade is 6 if only one condition is met.
Grade is 5 if none of three conditions are met.
Write a program, if the user gives values of hardness, carbon content and tensile strength of the steel under consideration and display the grade of the steel. 


TEST CASE 1

INPUT

2
53 0.7 5602
55 0 5499

OUTPUT

Grade 10
Grade 9


EXPLANATION :

The code is a basic decision making question , requiring to use if and else ifControl Statements ). The first input is the number of test cases that the user will input. Then there will be a set of three inputs referring to the values hardness, carbon content  and tensile strength respectively. We have to check the values under different conditions and rate the steel under different grades from 1 to 10 .


ALGORITHM :

  • Input the number of test cases from the user ( t )
  • Run loop from 0 to the number of test cases ( i<t )
  • Input the values of hardness, carbon content and tensile strength ( hs,cc,ts )
  • Check for grade 10 ( hs>=50&&cc<=0.700000000&&ts>=5600 )
  • Check for grade 9 ( hs>=50&&cc<=0.7 )
  • Check for grade 8 ( cc<=0.7&&ts>=5600 )
  • Check for grade 7 ( hs>=50&&ts>=5600 )
  • Check for grade 6 ( hs>=50||cc<=0.7||ts>=5600 )
  • If all the conditions are false then it is grade 5
  • Print the grade with required message
  • Redo this for all other test cases 

SOLUTION : (Please use this as reference only)

CODE


 

PLACING THE FLAG POST

QUESTION DESCRIPTION :

The shape of the college ground is Square. For the Independence day Flag Hoisting Function, it has been decided to place the flag post at the exact center of the ground. Can you please help them in placing the flag post at the exact center?
Given the coordinates of the left bottom vertex of the square ground and the length of the side, you need to write a program to determine the coordinates of the centre of the ground.
[Assumption --- Length of the side is always even]
Input Format:
Input consists of 3 integers. The first integer corresponds to the x-coordinate of the left bottom vertex. The second integer corresponds to the y-coordinate of the left bottom vertex. The third integer corresponds to the length of the square.


TEST CASE 1

INPUT

4 0 8

OUTPUT

centre of the ground is at(8,4)


EXPLANATION :

This question requires you to find the center of the square whose left bottom coordinates ( x,y ) and length is given. To find the coordinates we use basic geometry.

FORMULA :

Center X : x + l/2 , Center  Y : y +l/2


ALGORITHM :


  • Input the lower bottom x and y coordinates ( x,y )
  • Input the length of square side ( l )
  • Calculate the coordinates using the formula and print it with appropriate message ( print as int %d , "center" as used by me is from American English ) 

SOLUTION : (Please use this as reference only)

CODE

Find Remainder

QUESTION DESCRIPTION :


Write a program to find the remainder when two given numbers are divided.

Input

The first line contains an integer T, total number of test cases. Then follow T lines, each line contains two Integers A and B.

Output

Find remainder when A is divided by B.

Constraints

1 ? T ? 1000
1 ? A,B ? 10000


TEST CASE 1

INPUT

3
1 2
100 200
10 40

OUTPUT

Remainder is 1
Remainder is 100
Remainder is 10


EXPLANATION :

This problem is similar to Modulo Operations , but you have to do it for multiple inputs , the number of inputs is given by the first integer received from the user.


QUESTION ISSUES :

The constraints given contain " ? " but it should be either " < " or " <= "


ALGORITHM:

  • Input the number of test cases from the user ( t )
  • Run a loop till t , to get all input cases
  • Input the two numbers from the user ( a,b )
  • Compute the remainder using modulo operator ( a%b )
  • Print the result
  • Redo this for all other test cases 

SOLUTION : (Please use this as reference only)

CODE

Greedy puppy

QUESTION DESCRIPTION :

Tuzik is a little dog. But despite the fact he is still a puppy he already knows about the pretty things that coins are. He knows that for every coin he can get very tasty bone from his master. He believes that some day he will find a treasure and have loads of bones.

And finally he found something interesting. A wooden chest containing N coins! But as you should remember, Tuzik is just a little dog, and so he cant open it by himself. Actually, the only thing he can really do is barking. He can use his barking to attract nearby people and seek their help. He can set the loudness of his barking very precisely, and therefore you can assume that he can choose to call any number of people, from a minimum of 1, to a maximum of K.

When people come and open the chest they divide all the coins between them in such a way that everyone will get the same amount of coins and this amount is maximal possible. If some coins are not used they will leave it on the ground and Tuzik will take them after they go away. Since Tuzik is clearly not a fool, he understands that his profit depends on the number of people he will call. While Tuzik works on his barking, you have to find the maximum possible number of coins he can get.

Input
The first line of the input contains an integer T denoting the number of test cases. Each of next T lines contains 2 space-separated integers: N and K, for this test case.

Output
For each test case output one integer - the maximum possible number of coins Tuzik can get.

Constraints
1<=T<=50
1<=N, K<=105
In the first example he should call two people. Each of them will take 2 coins and they will leave 1 coin for Tuzik.

In the second example he should call 3 people


TEST CASE 1


INPUT

2
5 2
11 3

OUTPUT

1
2


EXPLANATION :

As the size of the inputs in the problem is very small ( in the order of 10^2 ) , we can simply use brute-forcing ( Brute Forcing ) and test every possible case and print the value of the maximum coins that the dog gets.

As the dog only gets what remains after equal spitting , this can be calculated by using the modulo " % "Modulo ) operation .

Example :

For 2'nd test case :  ( 11,3 ) :
  • He can call maximum of 3 people
  • If he calls only 1 person , the person will take all the coins , leaving him with nothing
  • If he calls 2 people , he will be left with only 1 coin , as the two people take 5 , 5 coins each.
  • If he calls 3 people , each one will take 3 coins , leaving him with 2 coins
  • So the best case for him is to call 3 people so he can get 2 coins.
The input format is :
  • An integer , to represent the number of test cases ( number of times the user will provide distinct values of N and K)
  • Pair of integers representing N and K values respectively ( this will be the input format for next t cases )
The result will be biggest modulo value that a number gives with N , such that the number is less than K.


ALGORITHM: 

  • Input an integer from the user, representing the number of test cases ( t )
  • Run a loop till the number ( for/while loop )
  • Accept two integers from the user ( n,k )
  • Take a variable "max" , to store the max coins the dog can get ( max=0 )
  • Run a loop from 1 till K ( for(j=1;j<=k;j++) )
  • Check the amount of coins left to him if he calls j number of people ( n%j )
  • If the value of coins left is more than previous max , replace it with previous max ( max=n%j )
  • After the loop exits , print the maximum value , with the required message ( max )
  • Change max back to 0 
  • Redo this for all the N,K values

SOLUTION : (Please use this as reference only)

CODE

Modulo of numbers(Integer data type)

QUESTION DESCRIPTION :

Jenny's home work for Fifth day is to find modulo of two numbers, help jenny to solve the problem.


TEST CASE 1
 
INPUT

6
2

OUTPUT

The reminder of two number is:0


EXPLANATION:

The code requires you to perform modulo "%"Modulo Operation ) operation on the two integers received from the user. 


ALGORITHM:  

  • Take two variables from the user ( a,b )
  • Calculate the modulo ( a%b )
  • Print it with the exact required message ( Spelling of remainder is wrong )

SOLUTION : (Please use this as reference only)

CODE

Size of Data Types

QUESTION DESCRIPTION :

Write a program to produce correct size of various data types on your computer


TEST CASE 1

INPUT

0

OUTPUT

Size of char:1
Size of int:4
Size of short int:2
Size of long int:8
Size of float:4
Size of double:8


EXPLANATION :

The problem requires you to print the exact size of the different data-types used in C. There are two methods of doing this , either print the size directly or use the sizeof() The sizeof() function ) function to print the exact size of the variable given in arguments.

ALGORITHM :

  • To directly print the exact size just use the print statement and put whatever is required to it.
Using the sizeof() operator :
  • Declare a variable of each type ( char , int , short , long , float , double
  • Use the sizeof() to get the size of each datatype ( sizeof( variable ) )
  • Print the long unsigned integer value Different Datatypes in C ) received from the sizeof() function with the exact output message ( %ld )

SOLUTION : (Please use this as reference only)

CODE (Direct Print)

CODE (Size Of)

Differenzia

QUESTION DESCRIPTION :

In a country named Differenzia the minors and senior citizens are not eligible to vote. Only people aged between 18 to 60 (both inclusive) are eligible to vote. Write a program to determine a person in Differenzia is eligible to vote.


TEST CASE 1 

INPUT

18

OUTPUT

Eligible


TEST CASE 2

INPUT

2

OUTPUT

Not Eligible


EXPLANATION :

The problem is a basic if else if else statements ) problem , that requires you to check weather the person who is going to vote is eligible to vote or not. The input is the age of a person and you have to check weather the age is between 18-60 , if yes , the person is eligible , else he is not.


ALGORITHM :

  • Take input from the user ( a )
  • Check the input satisfies the eligibility criteria or not ( a>=18 && a<=60 )
  • If yes , print Eligible
  • Otherwise print Not Eligible 
SOLUTION : (Please use this as reference only)

CODE





Number of digits

QUESTION DESCRIPTION :

C Program to Count number of digits in number without using mod operator


TEST CASE 1

INPUT

1234

OUTPUT

Number of Digits:4


TEST CASE 2

INPUT

874527

OUTPUT

Number of Digits:6


EXPLANATION :

The problem requires you to count the number of digits in a number being input. The method used is to continuously divide the number by 10 , to reduce the digits by 1 and increase the counter


ALGORITHM :

  • Take input from the user ( a )
  • Take a while loop , with the condition , number > 0 ( a>0 )
  • Divide the number by 10 and save it in the original variable ( a=a/10
  • Increase the count by 1 ( i++ )
  • Loop till the number becomes 0 ( loop condition is not satisfied )
  • Print the counter ( i )
SOLUTION : (Please use this as reference only)

CODE

Addition of numbers(Integer data type)

QUESTION DESCRIPTION :

Jennys home work for first day is to find addition of two numbers, help jenny to solve the problem.


TEST CASE 1 

INPUT

6
2

OUTPUT

The addition of two number is:8


EXPLANATION :

This is a simple problem which requires you to accept two numbers and then print addition of the first number and the second number.


ALGORITHM :

  • Take input from the user ( a,b )
  • Add the two numbers ( a+b ) 
  • Print the result.

SOLUTION : (Please use this as reference only)

CODE

Multiplication of numbers(Integer data type)

QUESTION DESCRIPTION :

Jennys home work for Third day is to find Multiplication of two numbers, help jenny to solve the problem.

TEST CASE 1 

INPUT

6
2

OUTPUT

The Multiplication of two number is:12


EXPLANATION :

This is a simple problem which requires you to accept two numbers and then print the multiplication of the first and the second number.

ALGORITHM :

  • Take input from the user ( a,b )
  • Multiply the two numbers and print the result.( a*b )

SOLUTION : (Please use this as reference only)

CODE



Float Division of numbers

QUESTION DESCRIPTION :

Harinis home work for fourth day is to divide two numbers, help Harini to solve the problem.


TEST CASE 1 

INPUT

7.2 3.4

OUTPUT

The Division of two number is:2.117647


EXPLANATION :

This is a simple problem which requires you to accept two numbers and then print the division of the first number by the second number. ( ImpDividing Two Integers Gives Integers )


ALGORITHM :
  • Take input from the user ( a,b )
  • As dividing two integers gives you an integer , you either need to parse ( Parsing ) it to float or take the input as float ( I took the input as float )
  • Divide the two numbers and print the result.( a/b )
SOLUTION : (Please use this as reference only)


CODE


Swap Numbers

QUESTION DESCRIPTION :

Write a C Program to swap two variables without using third or temp variable


TEST CASE 1 

INPUT

20
5

OUTPUT

Values after Swapping
value of a is:5
value of b is:20


EXPLANATION : 

The code requires you to receive an input of two numbers , swap them and display the results ( Different Swapping Methods ). I have used the mathematical approach.


ALGORITHM :

  • Take two inputs from the user ( a,b )
  • Add second value to the first value and store it in the first variable ( a=a+b )
  • To add new value to second variable , subtract the value of second variable from the value of the first variable and store it in the second one ( b=a-b )
  • Perform a similar operation on the first variable ( a=a-b )
  • The numbers are swapped , print them with the required output message.

SOLUTION : (Please use this as reference only)

CODE


IO 35

QUESTION DESCRIPTION :


Write a program to display a grocery bill of the product purchased in the small market by John by getting following input from the user

Get the product name
Get the price of the product(Price per Unit)
Get the quantity of the product purchased
Input and Output Format:

Refer sample input and output for formatting specification.

All float values are displayed correct to 2 decimal places.

All text in bold corresponds to input and the rest corresponds to output.


TEST CASE 1

INPUT

soap
33.00
2

OUTPUT

Product Details
soap
33.000000
2
Bill:66.00

EXPLANATION : 

The code requires you to receive an input of Product Name , Product Price and the Quantity of the product bought and then print the Billing Details. ( Strings )

ALGORITHM :

  • Take a string as a char array to receive the name of the product ( ch[500] )
  • Take two float variables and an integer variable to store bill amount, price of individual product and number of such products bought ( p , f  , u )
  • Receive the inputs for the respective categories from the user ( %s , %f , %d )
  • Multiply the individual product price with the number of products bought and store it in the bill amount ( p=u*f  )
  • Print the result according to the required format.

SOLUTION : (Please use this as reference only)

CODE


IO 9

QUESTION DESCRIPTION :

Let us help Raje to perform basic bitwise operation by providing three inputs given to the program with the following conditions are met,

Bitwise And
Bitwise OR
Bit Wise Not

Input and Output Format:

Refer sample input and output for formatting specification.

All float values are displayed correct to 2 decimal places.

All text in bold corresponds to input and the rest corresponds to output.


TEST CASE 1

INPUT

23 4

OUTPUT

Bitwise And of 23 and 4=4
Bitwise OR of 23 and 4=23
Bit Wise Not of 23 and 4=19


EXPLANATION:

The code requires you to print the AND( & ), OR ( | ) , NOT( ~ ) values of the given integer inputs. ( BITWISE OPERATIONS ). The input will be two integers , on which you have to perform BITWISE operations. ( How do BITWISE operators work ) 

ALGORITHM :


  • Accept the two numbers ( a,b )
  • Calculate AND of the two numbers ( a&b )
  • Calculate OR of the two numbers ( a|b )
  • Calculate XOR of the two numbers ( a^b )

QUESTION ISSUES :

The last operation " NOT " , requires only 1 input ( ~ works with only one input ). The result of the NOT case is the XOR value of the 2 inputs ( a^b ) 


SOLUTION : (Please use this as reference only)

CODE