MP2
This commit is contained in:
parent
601b7ebc0c
commit
5fcdbf27fd
BIN
Semester 2/Assignments/MP2_CalebFontenot/mp2-s23.pdf
Normal file
BIN
Semester 2/Assignments/MP2_CalebFontenot/mp2-s23.pdf
Normal file
Binary file not shown.
@ -0,0 +1,196 @@
|
||||
/*
|
||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||
*/
|
||||
package com.calebfontenot.mp2_calebfontenot;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author caleb
|
||||
*/
|
||||
public class Circle2D {
|
||||
|
||||
private double x;
|
||||
private double y;
|
||||
private double radius;
|
||||
|
||||
public Circle2D()
|
||||
{
|
||||
this.x = this.y = 0;
|
||||
this.radius = 1;
|
||||
}
|
||||
|
||||
public Circle2D(double x, double y, double radius)
|
||||
{
|
||||
this.x = x;
|
||||
this.y = y;
|
||||
this.radius = radius;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the value of x
|
||||
*
|
||||
* @return the value of x
|
||||
*/
|
||||
public double getX()
|
||||
{
|
||||
return x;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the value of y
|
||||
*
|
||||
* @return the value of y
|
||||
*/
|
||||
public double getY()
|
||||
{
|
||||
return y;
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the value of radius
|
||||
*
|
||||
* @return the value of radius
|
||||
*/
|
||||
public double getRadius()
|
||||
{
|
||||
return radius;
|
||||
}
|
||||
|
||||
public double getArea()
|
||||
{
|
||||
return Math.PI * this.radius * this.radius;
|
||||
}
|
||||
|
||||
public double getPerimeter()
|
||||
{
|
||||
return 2 * Math.PI * this.radius;
|
||||
}
|
||||
|
||||
@Override
|
||||
public String toString()
|
||||
{
|
||||
return "Circle2D{" + "x=" + x + ", y=" + y + ", radius=" + radius + '}';
|
||||
}
|
||||
|
||||
@Override
|
||||
public int hashCode()
|
||||
{
|
||||
int hash = 5;
|
||||
return hash;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean equals(Object obj)
|
||||
{
|
||||
if (this == obj) {
|
||||
return true;
|
||||
}
|
||||
if (obj == null) {
|
||||
return false;
|
||||
}
|
||||
if (getClass() != obj.getClass()) {
|
||||
return false;
|
||||
}
|
||||
final Circle2D other = (Circle2D) obj;
|
||||
if (Double.doubleToLongBits(this.x) != Double.doubleToLongBits(other.x)) {
|
||||
return false;
|
||||
}
|
||||
if (Double.doubleToLongBits(this.y) != Double.doubleToLongBits(other.y)) {
|
||||
return false;
|
||||
}
|
||||
return Double.doubleToLongBits(this.radius) == Double.doubleToLongBits(other.radius);
|
||||
}
|
||||
|
||||
/**
|
||||
* Determines if a point is inside the circle.
|
||||
*
|
||||
* @param x
|
||||
* @param y
|
||||
* @return true if the specified point (x, y) is inside the circle, otherwise false.
|
||||
*/
|
||||
public boolean contains(double x, double y)
|
||||
{
|
||||
double d = distance(x, y, this.x, this.y);
|
||||
return d <= radius;
|
||||
}
|
||||
|
||||
public boolean contains(Circle2D c)
|
||||
{
|
||||
double d = distance(c.x, c.y, this.x, this.y);
|
||||
return d <= radius;
|
||||
}
|
||||
|
||||
/**
|
||||
* Determines if this circle overlaps with parameter circle.
|
||||
*
|
||||
* @param circle to compare for overlapping.
|
||||
* @return true
|
||||
*/
|
||||
public boolean overlaps(Circle2D c)
|
||||
{
|
||||
// Compare this to the paremeter
|
||||
double overlap = Math.sqrt((Math.pow((this.x - c.x), 2) + Math.pow((this.y + c.y), 2)));
|
||||
|
||||
if (overlap <= (this.radius - c.radius)) {
|
||||
return true;
|
||||
} else if (overlap <= (c.radius - this.radius)) {
|
||||
return true;
|
||||
} else if (overlap < (this.radius + c.radius)) {
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
/**
|
||||
*
|
||||
* @param x1 x of point 1
|
||||
* @param y1 x of point 1
|
||||
* @param x2 x of point 1
|
||||
* @param y2 x of point 1
|
||||
* @return the distance between the two points
|
||||
*/
|
||||
private static double distance(double x1, double y1, double x2, double y2)
|
||||
{
|
||||
return Math.sqrt((x1 - x2) * (x1) * (x1 - x2)
|
||||
+ (y1 - y2) * (y1 - y2));
|
||||
}
|
||||
|
||||
/**
|
||||
* Sort the array in ascending order by perimeter i=size;
|
||||
*
|
||||
* @param array the array to be used for sorting, not altered.
|
||||
* @return a new sorted array;
|
||||
*/
|
||||
public static Circle2D[] sortCirclesByPerimeter(Circle2D[] array)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Sort the array in ascending order by perimeter size. Returns a new sorted array. You compare every circle with all other circles. If it overlaps with all others it should be placed first.
|
||||
*
|
||||
* @param array The array used for sorting.
|
||||
* @return
|
||||
*/
|
||||
public static Circle2D[] sortCirclesByNumberOfTimesOverlapping(Circle2D[] array)
|
||||
{
|
||||
return null;
|
||||
}
|
||||
|
||||
public static void main(String[] args)
|
||||
{
|
||||
Circle2D c1 = new Circle2D(2, 2, 5.5);
|
||||
System.out.println("Area is " + c1.getArea());
|
||||
System.out.println("Perimeter is " + c1.getPerimeter());
|
||||
//System.out.println(c1.contains(3, 3));
|
||||
//System.out.println(c1.contains(new Circle2D(4, 5, 10.5)));
|
||||
//System.out.println(c1.overlaps(new Circle2D(3, 5, 2.3)));
|
||||
//System.out.println(c1.overlaps(new Circle2D(-8.7, 5, 2.3)));
|
||||
//System.out.println(c1.overlaps(new Circle2D(-8.7, 5, 2.3)));
|
||||
System.out.println(c1.contains(new Circle2D(-1.9, 1.8, 2.3)));
|
||||
System.out.println(c1.overlaps(new Circle2D(-1.9, 1.8, 2.3)));
|
||||
}
|
||||
}
|
Loading…
x
Reference in New Issue
Block a user