generated from mate-academy/jv-homework-template
-
Notifications
You must be signed in to change notification settings - Fork 1.4k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Can you check my task, please? #1214
Open
IvanIKS
wants to merge
28
commits into
mate-academy:master
Choose a base branch
from
IvanIKS:master
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Changes from 26 commits
Commits
Show all changes
28 commits
Select commit
Hold shift + click to select a range
1a87a5d
update checklist.md (#1182)
boroda4436 939b3b6
Merge remote-tracking branch 'origin/master'
IvanIKS 58c52b9
Merge remote-tracking branch 'origin/master'
IvanIKS 98d410a
Merge remote-tracking branch 'origin/master'
IvanIKS f2d3fa2
Merge remote-tracking branch 'origin/master'
IvanIKS 4ec2d52
Merge remote-tracking branch 'origin/master'
IvanIKS 030b08e
Merge remote-tracking branch 'origin/master'
IvanIKS c7f9151
Merge remote-tracking branch 'origin/master'
IvanIKS bea0209
Merge remote-tracking branch 'origin/master'
IvanIKS 2216abf
Merge remote-tracking branch 'origin/master'
IvanIKS b5ad7f3
Merge remote-tracking branch 'origin/master'
IvanIKS d89778c
Merge remote-tracking branch 'origin/master'
IvanIKS a229576
Merge remote-tracking branch 'origin/master'
IvanIKS 6c9a798
Merge remote-tracking branch 'origin/master'
IvanIKS c5bd73d
Fixed problems.
IvanIKS 772eb65
Merge remote-tracking branch 'origin/master'
IvanIKS 833a81e
Merge remote-tracking branch 'origin/master'
IvanIKS bfcc2ba
Merge remote-tracking branch 'origin/master'
IvanIKS 459bafa
Merge remote-tracking branch 'origin/master'
IvanIKS 0245dfd
Merge remote-tracking branch 'origin/master'
IvanIKS 45c2358
Merge remote-tracking branch 'origin/master'
IvanIKS e20ed6f
Merge remote-tracking branch 'origin/master'
IvanIKS 83b79f5
Merge remote-tracking branch 'origin/master'
IvanIKS 611d5ff
Merge remote-tracking branch 'origin/master'
IvanIKS 388e486
Merge remote-tracking branch 'origin/master'
IvanIKS bfd7fcb
Merge remote-tracking branch 'origin/master'
IvanIKS 5cf1b11
Merge remote-tracking branch 'origin/master'
IvanIKS 68bc970
Merge remote-tracking branch 'origin/master'
IvanIKS File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change | ||||
---|---|---|---|---|---|---|
@@ -1,48 +1,109 @@ | ||||||
package core.basesyntax; | ||||||
|
||||||
import java.util.NoSuchElementException; | ||||||
import java.util.Objects; | ||||||
|
||||||
public class ArrayList<T> implements List<T> { | ||||||
private static final int BASE_SIZE = 10; | ||||||
private static final double CAPACITY_INDEX = 1.5; | ||||||
private T[] elements; | ||||||
private int size; | ||||||
|
||||||
public ArrayList() { | ||||||
elements = (T[]) new Object[BASE_SIZE]; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public void add(T value) { | ||||||
|
||||||
resize(); | ||||||
elements[size] = value; | ||||||
size++; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public void add(T value, int index) { | ||||||
|
||||||
checkAddIndex(index); | ||||||
resize(); | ||||||
System.arraycopy(elements, index, elements, index + 1, size - index); | ||||||
elements[index] = value; | ||||||
size++; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public void addAll(List<T> list) { | ||||||
|
||||||
for (int i = 0; i < list.size(); ++i) { | ||||||
add(list.get(i)); | ||||||
} | ||||||
} | ||||||
|
||||||
@Override | ||||||
public T get(int index) { | ||||||
return null; | ||||||
checkIndex(index); | ||||||
return elements[index]; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public void set(T value, int index) { | ||||||
|
||||||
checkIndex(index); | ||||||
elements[index] = value; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public T remove(int index) { | ||||||
return null; | ||||||
checkIndex(index); | ||||||
T removedElement = elements[index]; | ||||||
System.arraycopy(elements, index + 1, elements, index, size - index - 1); | ||||||
size--; | ||||||
return removedElement; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public T remove(T element) { | ||||||
return null; | ||||||
int index = findElement(element); | ||||||
remove(index); | ||||||
return element; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public int size() { | ||||||
return 0; | ||||||
return size; | ||||||
} | ||||||
|
||||||
@Override | ||||||
public boolean isEmpty() { | ||||||
return false; | ||||||
return size == 0; | ||||||
} | ||||||
|
||||||
private void resize() { | ||||||
if (size == elements.length) { | ||||||
int newLength = (int) (elements.length * CAPACITY_INDEX); | ||||||
Object[] newArray = new Object[(int) newLength]; | ||||||
System.arraycopy(elements, 0, newArray, 0, elements.length); | ||||||
elements = (T[]) newArray; | ||||||
} | ||||||
} | ||||||
|
||||||
private int findElement(T element) { | ||||||
for (int i = 0; i < size; ++i) { | ||||||
if (Objects.equals(element, elements[i])) { | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. |
||||||
return i; | ||||||
} | ||||||
} | ||||||
throw new NoSuchElementException("You're trying to remove element \"" | ||||||
+ element + "\", that is not present in the list"); | ||||||
} | ||||||
|
||||||
private void checkIndex(int index) { | ||||||
if (index < 0 || index >= size) { | ||||||
throw new ArrayListIndexOutOfBoundsException("Can't reach element on position " | ||||||
+ index + " in a list with size of " + size + " ."); | ||||||
} | ||||||
} | ||||||
|
||||||
private void checkAddIndex(int index) { | ||||||
if (index < 0 || index > size + 1) { | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
throw new ArrayListIndexOutOfBoundsException("Can't add element to position " | ||||||
+ index + " in a list with size of " + size + " ."); | ||||||
} | ||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. add
|
||||||
} | ||||||
} |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.