gpt4 book ai didi

java - 删除和替换 java 方法

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:01:39 27 4
gpt4 key购买 nike

因此,我很难为以下问题概念化答案。我不是在寻找答案,而是在寻找我可以采取的有用步骤,这些步骤将使我能够自己提出答案。注意:为了回答这些问题,我得到了引用类和驱动程序。问题如下:

Q.1 为 ADT 包实现一个替换方法,用给定对象。

Q.2.编写一个删除方法来删除 ArrayBag 中元素的每个实例。

问题 3。至少给出两个适用于固定包的情况的例子和两个适用于可调整大小包的情况的例子。

下面的代码是我开始的,但不确定我的方向是否正确:

a.1 public T replace(T theItem) {
Random generator = new Random();
int randomPosition = generator.nextInt(numberOfEntries);

T result = null;

if (!isEmpty() && (randomPosition >= 0)) {
result = bag[randomPosition]; // Entry to remove
bag[randomPosition] = theItem; // Replace entry to remove with
// last entry

}
return result;
a.2 public void clear(T theItem) {
while (!this.isEmpty(ArrayBag))
this.remove();

a.3 not sure it should be related to coding examples or something else.

另外,ArrayBag的类如下,供引用:

import java.util.Arrays;
import java.util.Random;

public final class ArrayBag<T> implements BagInterface<T> {
private final T[] bag;
private int numberOfEntries;
private boolean initialized = false;
private static final int DEFAULT_CAPACITY = 25;
private static final int MAX_CAPACITY = 10000;

/** Creates an empty bag whose initial capacity is 25. */
public ArrayBag() {
this(DEFAULT_CAPACITY);
} // end default constructor

/**
* Creates an empty bag having a given capacity.
*
* @param desiredCapacity
* The integer capacity desired.
*/
public ArrayBag(int desiredCapacity) {
if (desiredCapacity <= MAX_CAPACITY) {
// The cast is safe because the new array contains null entries
@SuppressWarnings("unchecked")
T[] tempBag = (T[]) new Object[desiredCapacity]; // Unchecked cast
bag = tempBag;
numberOfEntries = 0;
initialized = true;
} else
throw new IllegalStateException("Attempt to create a bag "
+ "whose capacity exceeds " + "allowed maximum.");
} // end constructor

/**
* Adds a new entry to this bag.
*
* @param newEntry
* The object to be added as a new entry.
* @return True if the addition is successful, or false if not.
* /
public boolean add(T newEntry) {
checkInitialization();
boolean result = true;
if (isArrayFull()) {
result = false;
} else { // Assertion: result is true here
bag[numberOfEntries] = newEntry;
numberOfEntries++;
} // end if

return result;
} // end add

/**
* Retrieves all entries that are in this bag.
*
* @return A newly allocated array of all the entries in this bag.
*/
public T[] toArray() {
checkInitialization();

// The cast is safe because the new array contains null entries.
@SuppressWarnings("unchecked")
T[] result = (T[]) new Object[numberOfEntries]; // Unchecked cast

for (int index = 0; index < numberOfEntries; index++) {
result[index] = bag[index];
} // end for

return result;
// Note: The body of this method could consist of one return statement,
// if you call Arrays.copyOf
} // end toArray

/**
* Sees whether this bag is empty.
*
* @return True if this bag is empty, or false if not.
*/
public boolean isEmpty() {
return numberOfEntries == 0;
} // end isEmpty

/**
* Gets the current number of entries in this bag.
*
* @return The integer number of entries currently in this bag.
*/
public int getCurrentSize() {
return numberOfEntries;
} // end getCurrentSize

/**
* Counts the number of times a given entry appears in this bag.
*
* @param anEntry
* The entry to be counted.
* @return The number of times anEntry appears in this ba.
*/
public int getFrequencyOf(T anEntry) {
checkInitialization();
int counter = 0;

for (int index = 0; index < numberOfEntries; index++) {
if (anEntry.equals(bag[index])) {
counter++;
} // end if
} // end for

return counter;
} // end getFrequencyOf

/**
* Tests whether this bag contains a given entry.
*
* @param anEntry
* The entry to locate.
* @return True if this bag contains anEntry, or false otherwise.
*/
public boolean contains(T anEntry) {
checkInitialization();
return getIndexOf(anEntry) > -1; // or >= 0
} // end contains

/** Removes all entries from this bag. */
public void clear() {
while (!this.isEmpty())
this.remove();
} // end clear

/**
* Removes one unspecified entry from this bag, if possible.
*
* @return Either the removed entry, if the removal was successful, or null.
*/
public T remove() {
checkInitialization();
T result = removeEntry(numberOfEntries - 1);
return result;
} // end remove

/**
* Removes one occurrence of a given entry from this bag.
*
* @param anEntry
* The entry to be removed.
* @return True if the removal was successful, or false if not.
*/
public boolean remove(T anEntry) {
checkInitialization();
int index = getIndexOf(anEntry);
T result = removeEntry(index);
return anEntry.equals(result);
} // end remove

public boolean removeRandom() {
Random generator = new Random();
int randomPosition = generator.nextInt(numberOfEntries);
T result = removeEntry(randomPosition);
if (result == null) {
return false;
} else {
return true;
}

}

@Override
public boolean equals(Object obj) {
if (obj instanceof ArrayBag) {
ArrayBag<T> otherArrayBag = (ArrayBag<T>) obj;

if (numberOfEntries == otherArrayBag.numberOfEntries) {

// I create new arrays so that I can manipulate them
// and it will not alter this.bag or otherArrayBag.bag
T[] currentBagTempArray = toArray();
T[] otherBagTempArray = otherArrayBag.toArray();

Arrays.sort(currentBagTempArray);
Arrays.sort(otherBagTempArray);

for (int i = 0; i < numberOfEntries; i++) {
if (!currentBagTempArray[i].equals(otherBagTempArray[i])) {
return false;
}
}
return true;
} else {
return false;
}

} else {
return false;
}
}

public ResizableArrayBag<T> createResizableArray() {
T[] currentBagContents = toArray();
ResizableArrayBag<T> newBag = new ResizableArrayBag<T>(currentBagContents);
return newBag;
}

// Returns true if the array bag is full, or false if not.
private boolean isArrayFull() {
return numberOfEntries >= bag.length;
} // end isArrayFull

// Locates a given entry within the array bag.
// Returns the index of the entry, if located,
// or -1 otherwise.
// Precondition: checkInitialization has been called.
private int getIndexOf(T anEntry) {
int where = -1;
boolean found = false;
int index = 0;

while (!found && (index < numberOfEntries)) {
if (anEntry.equals(bag[index])) {
found = true;
where = index;
} // end if
index++;
} // end while

// Assertion: If where > -1, anEntry is in the array bag, and it
// equals bag[where]; otherwise, anEntry is not in the array.

return where;
} // end getIndexOf

// Removes and returns the entry at a given index within the array.
// If no such entry exists, returns null.
// Precondition: 0 <= givenIndex < numberOfEntries.
// Precondition: checkInitialization has been called.
private T removeEntry(int givenIndex) {
T result = null;

if (!isEmpty() && (givenIndex >= 0)) {
result = bag[givenIndex]; // Entry to remove
int lastIndex = numberOfEntries - 1;
bag[givenIndex] = bag[lastIndex]; // Replace entry to remove with
// last entry
bag[lastIndex] = null; // Remove reference to last entry
numberOfEntries--;
} // end if

return result;
} // end removeEntry

// Throws an exception if this object is not initialized.
private void checkInitialization() {
if (!initialized)
throw new SecurityException(
"ArrayBag object is not initialized properly.");
} // end checkInitialization

}//结束 ArrayBag

最佳答案

其他人在 Bag Class Implementation in Java/Using Array 处使用数组实现了 Bag .我只看了一眼代码,所以它可能是一个混合包。

我假设 Bag 就像一个 Set,除了 in 可以多次存储同一个对象。您可能想要实现某种私有(private)集合(可能是像上面那样的数组)。我们称它为 myBag。由于您使用的是通用类型 T,您的 Bag 将只包含类型 T 的对象。

对于 Q1,您的 replace() 方法可能需要采用两个参数:要替换的对象(例如 findMe)和您要替换的对象(例如 replacement)。如果您的 Bag 可以容纳重复项,那么您可能想要替换第一个匹配的对象。与其使用 Random(),您可能需要通过 myBag 逐个元素,并将找到的元素替换为您要替换的元素。如果找不到 findMe,您可能想抛出一个错误。所以方法声明可能是这样的:

public boolean replace(T findMe, T replacement)

如果找到 findMe 则返回 true,否则返回 false。

对于 Q2,您可以创建一个 while 循环,在 myBag 的大小 > 0 时删除 myBag 中的第一个元素。

对于第 3 季度,不涉及编码。这是一道思考题。一般来说,如果一开始就知道尺寸不会改变,那么固定尺寸的 Bag 会很有帮助。

可调整大小的包在更多情况下是有意义的,您一开始并不知道尺寸,它很可能会收缩或增长,例如,一个类(class)的等候名单。

关于java - 删除和替换 java 方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28353351/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com