Friday, August 30, 2019

Composition or Has-A relationship in JAVA

Composition or Has-A relationship

          Composition is the design technique to implement has-a relationship in classes. We can use java inheritance or Object composition for code reuse. 

Java composition is achieved by using instance variables that refer to other objects. 



Program in JAVA:(taken simple example to explain composition)

package composition;

public class Book
{

private String title;
private int pages;
int count=0;
public Book(String title, int pages)
{
this.title=title;
this.pages=pages;
}
public void openBook()
{
System.out.println("book is opened start writing...");
}
public void turnPage()

count++;
if(count<=this.pages)
{
System.out.println("turning page...");
}
else
{
System.out.println("pages over...");
}
}
public void colseBook()
{
System.out.println("close the book...");
}
public void bookDetails()
{
                 System.out.println("The title of the book is "+this.title+" and it                               contains "+this.pages+" pages");
}
}
class Pen
{
private String colour;
public Pen(String colour)
{
this.colour=colour;
}
public void write()
{
System.out.println("write the content in the book with "+this.colour+" colour");
}
}
class Arthur
{
String name;
Book b;    //using class as a derived variables
Pen p;      //using class as a derived variables
public Arthur(String name,Book b,Pen p)
{
this.name=name;
this.b=b;
this.p=p;
}
public void writeContent()
{
b.openBook();
b.turnPage();
p.write();
b.colseBook();
}
public void bookDetails()
{
b.bookDetails();
}
}
class Main
{
public static void main(String [] args)
{
Arthur a=new Arthur("kookie",new Book("BTS",29),new Pen("Black"));
a.writeContent();
a.bookDetails();
}
}

Wednesday, August 28, 2019

Abstraction in JAVA

ABSTRACTION


 Abstraction: hiding of method implementation and showing only method signature is called "Abstraction".


Program in JAVA:


package abstraction;

public interface Distance
{
public void go();
}
class Walk implements Distance //class is hided for user
{
public void go()      //implementation is also hided
{
System.out.println("go and save your life..");
}
}
class Helper    // class is used to create an object for an user
{
public static Distance helpMethod()
{
Distance d1 = new Walk();  //here we use upcasting to hide the method
return d1;                              // implementation
}
}
class Main
{
public static void main (String [] args)
{
Distance d2 = Helper.helpMethod();
d2.go();
}
}

Generalization in JAVA

    GENERALIZATION
Program in JAVA:

(other members are eliminated for better understanding..)
package generalization;

public interface Distance
{
public void go();
}
class OnCycle implements Distance
{
public void go()
{
System.out.println("covered 2 km on cycle...");
}
}
class OnBike implements Distance
{
public void go()
{
System.out.println("covered 5 km on bike...");
}
}
class OnCar implements Distance
{
public void go()
{
System.out.println("covered 7 km on car...");
}
}
class Generalization
{
public static void move(Distance d1)  //Generalized method
{
d1.go();            //which uses up casting process
}
public static void main (String [] args)
{
move(new OnCycle());  //Distance d1= new OnCycle();
move(new OnBike());   //Distance d1= new OnBike();
move(new OnCar());    //Distance d1= new OnCar();
}
}

Friday, August 23, 2019

upstream and down stream in java

class A      //names of classes are simplified for better understanding
{
public void t1()
{
System.out.println("in t1 method...");
}
}
class B extends A
{
public void t2()
{
System.out.println("in t2 method....");
}
}
class C extends B
{
public void t3()
{
System.out.println("in t3 method....");
}
}
public class Streams {   //upstream and down stream
public static void main(String [] args)
{
B rv1= new C();//upstram  // (or) B rv1 = (B) new C();
rv1.t1();                             // this is possible because there is
rv1.t2();                            //only one super class for every subclass
A rv2 =(A) rv1; //upstream
rv2.t1();
B rv3=(B) rv2;   //downstream
rv3.t1();
rv3.t2();
C rv4 = (C) rv3;//downstream
rv4.t1();
rv4.t2();
rv4.t3();
}
}

specialization of methods in java

abstract class Shape
{
abstract public void area();
}
class Circle extends Shape
{
final static double pi=3.14;
int r;
public Circle(int r)
{
this.r=r;
}
public void area()
{
System.out.println(pi*r*r);
}
public static void printArea(Circle c1)
{
c1.area();
}
}
class Rectangle extends Shape
{
int l;
int b;
public Rectangle(int l,int b)
{
this.l=l;
this.b=b;
}
public void area()
{
System.out.println(l*b);
}
public static void printArea(Rectangle r1)
{
r1.area();
}
}
class Triangle extends Shape
{
int b,h;
public Triangle(int b,int h)
{
this.b=b;
this.h=h;
}
public void area()
{
System.out.println(0.5*b*h);
}
public static void printArea(Triangle t1)
{
t1.area();
}
}
public class Specialization
{
public static void main (String [] args)
{
Circle.printArea(new Circle(2));
Circle.printArea(new Circle(7));
Rectangle.printArea(new Rectangle(2,3));
Rectangle.printArea(new Rectangle(5,7));
Triangle.printArea(new Triangle(3,4));
Triangle.printArea(new Triangle(7,9));
}
   
}

Monday, August 5, 2019

Sports Tournament

Sports Tournament 


The company XYZ is hosting a cricket tournament for its employees. The teams are to be built by different departments and the format of the tournament will be knockout. The HR lead is busy with preparations and has done all the promotions. The sponsors are very keen for the tournament and have raised queries about it. The sponsors have asked about the number of matches that needs to be played. Here is where the HR executive is unable to help as he made all the preparations but forgot about the basic questions. He badly needs your help to find the number of matches they have to organize.


The HR has provided you with the total number of teams(N) that registered for the tournament. If there is any team left out to be paired then it automatically gets promoted to the next round. Now it is only you who can save the HR from embarrassment by solving the problem.


Input Format
The first line of input consists of the number of test cases T.
Next T lines consist of the number of teams participating in the tournament, N.

Constraints
1<= T <=100
2<= N <=100000

Output Format
For each test case, print the number of matches that have to be played.

Sample TestCase 1
Input
2
4
7
Output
3
6
Explanation
Test Case 1: N = 4 = 2 + 1 = 3
Test Case 2: N = 7 = 3 + 2 + 1 = 6

PROGRAM IN C:

#include <stdio.h> int main() { int cases,arr1[100],k=0,arr2[100]; //printf("no.of cases"); scanf("%d",&cases); for(int x=0;x<cases;x++) arr2[x]=0; for(int i=0;i<cases;i++) { scanf("%d",&arr1[i]); } for(int j=0;j<cases;j++) { while(arr1[j]>1) { if(arr1[j]%2==0) { arr2[k]=arr2[k]+arr1[j]/2; arr1[j]=arr1[j]/2; } else { arr2[k]=arr2[k]+arr1[j]/2; arr2[k]++; arr1[j]=arr1[j]/2; } } k++; } for(int l=0;l<cases;l++) printf("%d\n",arr2[l]); return 0; }

Tuesday, July 23, 2019

The Hare and the Tortoise race

The Hare and the Tortoise race 



We all have heard the story of the hare and the tortoise. Last time the hare lost the race to the tortoise because of his laziness. Since then the hare has been requesting the tortoise for a rematch numerous times and the tortoise has been always declining his request. Just a couple of days before the tortoise has agreed for a rematch on the condition that he will decide the route of the match.

race between a hare and the tortoise has to happen on the hills of the Nilgiri forest. Nilgiri forest has N hills numbered from 1 to N. Some of these hills are connected by paths called forest paths. Since these paths can have sharp corners which can lead to two animals bumping into each other if they come from opposite directions, so the forest government have made them one-way.
You  are given the time taken by the tortoise and the hare to move along a road for every forest road. Nilgiri has total M forest roads which are unidirectional.

The race can start from any hill but it should also end on the same hill. In other words, the path of the race should be cyclic.
The tortoise is now thinking of the route to take which involves the minimum number of roads and the tortoise is strictly faster than the hare on this route. If there are multiple such routes, the tortoise will choose the one which leads to the tortoise winning by the biggest margin (so that the hare doesn't dare to challenge the tortoise again in future).

It is guaranteed that such a route always exists.

Input Format
The first line contains 2 space-separated integers N and M representing the number of hills and the number of forest roads.

Next follows M lines. The ith line contains 4 integers ui, vi, ti, hi - ui and vi represents the starting and ending hills of a forest road respectively, ti and hi represents the time taken to cross this road by the tortoise and the hare respectively.

Constraints
2 <= N <= 4
2 <= M <= N(N-1)
1 <= ui, vi <= N  (ui != vi)
0 <= ti, hi <= 1000,000,000

Output Format
You have to print two space-separated integers - the first one is the minimum number of roads in the chosen path, and the second one is the biggest margin by which the tortoise can win the race on the chosen route.
Sample TestCase 1
Input
4 5
1 2 2 10
2 3 4 400
3 4 8 100
4 3 2 5
3 1 1 1000

Output
2 95
Explanation

You can see, the best route is 3 ---> 4 ----> 3 which consists of 2 roads only. The margin by which the tortoise wins = (100 + 5) - (8 + 2) = 105 - 10 = 95.



PROGRAM IN C:

#include<stdio.h>
int main()
{
     int arr[10][10],value[10],count=0,q=0,result=0,v=0,array1,array2;
scanf("%d",&array2); scanf("%d",&array1); for(int i=1;i<=array1;i++) { for(int j=1;j<=array2;j++) { scanf("%d",&arr[i][j]); } } for(int k=0;k<array1;k++) { if((arr[k][1]==arr[k+1][2])&&(arr[k][2]==arr[k+1][1])) { value[v]=k; count+=2; v++; } } for(int z=0;z<v;z++)
{ q=value[z]; result=result+(arr[q][4]+arr[q+1][4])-(arr[q][3]+arr[q+1][3]);
} printf("%d %d",count,result); return 0;
}

Friday, July 19, 2019

Kth largest factor of N

               kth largest factor of N 

A positive integer d is said to be a factor of another positive integer N if when N is divided by d, the remainder obtained is zero. For example, for number 12, there are 6 factors 1, 2, 3, 4, 6, 12. Every positive integer k has at least two factors, 1 and the number k itself. Given two positive integers N and k, write a program to print the kth largest factor of N. 
Input Format: The input is a comma-separated list of positive integer pairs (N, k)
Output Format: The kth highest factor of N. If N does not have k factors, the output should be 1.
Constraints: 1<N<10000000000. 1<k<600. You can assume that N will have no prime factors which are larger than 13.
Example 1
  • Input: 12,3
  • Output: 4
Explanation: N is 12, k is 3. The factors of 12 are (1,2,3,4,6,12). The highest factor is 12 and the third-largest factor is 4. The output must be 4
Example 2
  • Input: 30,9
  • Output: 1
Explanation: N is 30, k is 9. The factors of 30 are (1,2,3,5,6,10,15,30). There are only 8 factors. As k is more than the number of factors, the output is 1.



Program in C:

#include <stdio.h>
int main()
{
    int num,position,a[50],n=0;
    char ch;
    scanf("%d%c%d",&num,&ch,&position);
    for (int i=1;i<=num;i++)
       {
           if(num%i==0)
           {
               a[n]=i;
               n++;
           }
           
       }
       if(n>=position)
        printf("%d",a[position]);
       else
        printf("1");
    return 0;
}

Thursday, July 18, 2019

counting rock samples

Counting Rock Samples

Juan Marquinho is a geologist and he needs to count rock samples in order to send it to a chemical laboratory. He has a problem: The laboratory only accepts rock samples by a range of its size in ppm (parts per million).
Juan Marquinho receives the rock samples one by one and he classifies the rock samples according to the range of the laboratory. This process is very hard because the number of rock samples may be in millions.
Juan Marquinho needs your help, your task is to develop a program to get the number of rocks in each of the ranges accepted by the laboratory.
Input Format:
An positive integer S (the number of rock samples) separated by a blank space, and a positive integer R (the number of ranges of the laboratory); A list of the sizes of S samples (in ppm), as positive integers separated by space R lines where the ith line containing two positive integers, space-separated, indicating the minimum size and maximum size respectively of the ith range.
Output Format:
R lines where the ith line containing a single non-negative integer indicating the number of the samples which lie in the ith range.
Constraints: 10 ≤ S ≤ 10000 1 ≤ R ≤ 1000000 1≤size of each sample (in ppm) ≤ 1000
Example 1
Input: 10 2
           345 604 321 433 704 470 808 718 517 811
           300 350
           400 700
Output: 2 4


Program in C:

#include <stdio.h>

int main()
{
     int m,n,a[50],b[10][1],c[10];               // m= number of rocks collected
   char ch;                                                 //n= number of labs
   scanf("%d%c%d",&m,&ch,&n);         //ch to read space
   printf("\n");                                          //a[50] = diff sizes of rocks collected
   for(int i=0;i<m;i++)                            //b[10][1]= to store min and max sizes of
      scanf("%d",&a[i]);                                           //labs in two dimentional array
    for (int j=0;j<n;j++)                           //c[10]= to sore the number of rocks that
                                                                                //are suitable to labs
scanf("%d%c%d",&b[j][0],&ch,&b[j][1]);         
      for (int k=0;k<n;k++)
          c[k]=0;
    for(int l=0;l<n;l++)
    {
        for (int x=0;x<m;x++)
        {
        if(a[x]>=b[l][0] && a[x]<=b[l][1])
            c[l]++;
        }
    }
   for (int y=0;y<n;y++)
         printf("%d ",c[y]);
    return 0;

}

pattern program 3

To Print The Following Pattern 




Program in C:

#include <stdio.h>

int main()
{
  int star = 0, space = 5;
  for (int i=1;i<=9;i++)
  {
  if(i<=5)
  {
  space--;
  star++;
  }
  else
  {
  space++;
  star--;
  }
  for (int j=1;j<=space;j++)
  printf(" ");
  for (int k=1;k<=star;k++)
  printf("*");
  for(int l=1;l<=8;l++)
  {
  if(i<=3 || i>6)
  printf(" ");
  else
  printf("*");
  }
  for (int m=1;m<=star;m++)
  printf("*");
  printf("\n");
  }
    return 0;
}



Program in JAVA:

public class Pattern {
  public static void main(String [] args)
  {
  int star = 0, space = 5;
  for (int i=1;i<=9;i++)
  {
  if(i<=5)
  {
  space--;
  star++;
  }
  else
  {
  space++;
  star--;
  }
  for (int j=1;j<=space;j++)
  System.out.print(" ");
  for (int k=1;k<=star;k++)
  System.out.print("*");
  for(int l=1;l<=8;l++)
  {
  if(i<=3 || i>6)
  System.out.print(" ");
  else
  System.out.print("*");
  }
  for (int m=1;m<=star;m++)
  System.out.print("*");
  System.out.println(" ");
  }
  }
}

Wednesday, July 17, 2019

pattern program 2

                                         Print The Following Pattern


Program in C:

#include <stdio.h>
int main()
{
    for(int i=1;i<=5;i++)
    {
      for(int j=5;j>i;j--)
          printf(" ");
      for(int l=1;l<2*i;l++)
          printf("*");
      printf("\n");   
    }

    return 0;
}


Program in JAVA:

public class Pattern
{
public static void main(String[] args)
{
   for(int i=1;i<=5;i++)
         {
              for(int j=5;j>i;j--)
                 System.out.print(" ");
              for(int l=1;l<2*i;l++)
                 System.out.print("*");
             System.out.println();   
           }
}
}

pattern program 1


Program to print the following pattern




Program in C:


#include <stdio.h>
int main()
{
    for(int i=1;i<=5;i++)
    {
      for(int j=1;j<=i;j++)
          printf("*");
      for(int k=(10-2*i);k>=1;k--)
          printf(" ");
      for(int l=1;l<=i;l++)
          printf("*");
      printf("\n");   
    }

    return 0;
}


Program in JAVA:

public class Pattern1
{
public static void main(String[] args)
{
    for(int i=1;i<=5;i++)
             {
                for(int j=1;j<=i;j++)
                      System.out.print("*");
               for(int k=(10-2*i);k>=1;k--)
                      System.out.print(" ");
               for(int l=1;l<=i;l++)
                     System.out.print("*");
             System.out.println(); 
           }
}
}

Tuesday, July 9, 2019

Converting the candies shape

Question from TechGig:

Converting the candies shape
An Annual learning competition was organised by a college in its various branches. Various students enrolled their name in the competition for their participation. Children are assigned a task on the spot about a puzzle which they have to solve in a very limited duration of time. They have been given a right isosceles triangle made of n > 0 lines containing 1, 3, . . . , 2n − 1 identical candies, respectively. They have to find out the minimum number of candies that will be needed to move these candies to create a square made up of all the candies given in the triangle. The student who solves this puzzle first will be awarded first and so on..

You have to return the minimum number of candies that is needed to move to convert the isosceles triangle into square made up of all the candies.


For example, assuming the number of lines of candies in the triangle is 3.




                                                                                         

Hence, the minimum number of candies that is needed to move to convert the isosceles triangle into square will be 2.

Input Format
Total number of lines of candies in the triangle.

Constraints
0 < N <=10000

Output Format
The minimum number of candies that are needed to move to convert the isosceles triangle into a square.

Sample TestCase 1
Input
3
Output
2


PROGRAM IN C:

#include<stdio.h>
int main(int argc, char *a[])
{
int i,number,result1,result2;
printf("Give the value of heigh");
scanf("%d",&number);
number=(number-1)/2;
for(i=1;i<=number;i++)
result1=result1+i;
result2=result1*2;
printf("%d",result2);
return 0;  
}

PROGRAM IN JAVA:


import java.util.Scanner; public class Main
{
  public static void main(String [] args)    {     int number,result1=0,result2=0;     System.out.println("Give the value of height");     Scanner input = new Scanner(System.in); number = input.nextInt(); number=(number-1)/2; for(int i=1;i<=number;i++) result1=result1+i; result2=result1*2; System.out.println(result2); } }