當前位置: 首頁>>代碼示例>>Java>>正文


Java PriorityQueue.offer方法代碼示例

本文整理匯總了Java中java.util.PriorityQueue.offer方法的典型用法代碼示例。如果您正苦於以下問題:Java PriorityQueue.offer方法的具體用法?Java PriorityQueue.offer怎麽用?Java PriorityQueue.offer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.util.PriorityQueue的用法示例。


在下文中一共展示了PriorityQueue.offer方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: computeRelaxation

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * 
 * @param arc
 * @param paths
 * @param distances
 * @param queue
 */
private void computeRelaxation(Arc arc, Map<Node, ResidualArc> paths,
        Map<Node, Integer> distances, PriorityQueue<Node> queue) {
    Node srcNode = arc.getSourceNode();
    Node destNode = arc.getDestinationNode();
    int sd = distances.get(srcNode);
    int dd = distances.get(destNode);
    int cost = arc.getCost();

    if (dd > sd + cost) {
        distances.put(destNode, sd + cost);
        paths.put(destNode, (ResidualArc) arc);

        // There can be multiple instance of the same node in the queue.
        // This is the only way to update the queue.
        queue.offer(destNode);
    }
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:25,代碼來源:MinimumBendOrthogonalizer.java

示例2: main

import java.util.PriorityQueue; //導入方法依賴的package包/類
public static void main(String[] args) 
{
   // queue of capacity 11
   PriorityQueue<Double> queue = new PriorityQueue<>();

   // insert elements to queue
   queue.offer(3.2);
   queue.offer(9.8);
   queue.offer(5.4);

   System.out.print("Polling from queue: ");

   // display elements in queue
   while (queue.size() > 0)
   {
      System.out.printf("%.1f ", queue.peek()); // view top element
      queue.poll(); // remove top element
   } 
}
 
開發者ID:cleitonferreira,項目名稱:LivroJavaComoProgramar10Edicao,代碼行數:20,代碼來源:PriorityQueueTest.java

示例3: testInQueue

import java.util.PriorityQueue; //導入方法依賴的package包/類
@Test
public void testInQueue() {
    PriorityQueue<ExponentialBackoff> queue = new PriorityQueue<>();
    ExponentialBackoff backoff1 = new ExponentialBackoff(params);
    backoff.trackFailure();
    backoff.trackFailure();
    backoff1.trackFailure();
    backoff1.trackFailure();
    backoff1.trackFailure();
    queue.offer(backoff);
    queue.offer(backoff1);

    assertEquals(queue.poll(), backoff); // The one with soonest retry time
    assertEquals(queue.peek(), backoff1);

    queue.offer(backoff);
    assertEquals(queue.poll(), backoff); // Still the same one
}
 
開發者ID:creativechain,項目名稱:creacoinj,代碼行數:19,代碼來源:ExponentialBackoffTest.java

示例4: main

import java.util.PriorityQueue; //導入方法依賴的package包/類
public static void main(String[] args) {
    
    PriorityQueue<Integer> pq = new PriorityQueue<>();
    
    // offer (add) some element
    pq.offer(3);
    pq.offer(2);
    pq.offer(4);
    System.out.println("Offer Some Element, autosort. Content: " + pq.toString());
            
    // add
    pq.add(1);        
    pq.add(5);
    pq.add(2);
    System.out.println("Add some element, autosort. Content: "+pq.toString());
    
    // peek head element
    System.out.println("Peek is " + pq.peek());
    
    // poll head element
    System.out.println("Poll is " + pq.poll()+", content: " + pq.toString());                        
}
 
開發者ID:mkdika,項目名稱:learnjava8,代碼行數:23,代碼來源:TestPriorityQueue.java

示例5: improve

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Replace a given path with that of this candidate move.
 *
 * @param openMap The list of available nodes.
 * @param openMapQueue The queue of available nodes.
 * @param f The heuristic values for A*.
 * @param sh An optional {@code SearchHeuristic} to apply.
 */
public void improve(HashMap<String, PathNode> openMap,
    PriorityQueue<PathNode> openMapQueue,
    HashMap<String, Integer> f,
    SearchHeuristic sh) {
    PathNode best = openMap.get(dst.getId());
    if (best != null) {
        openMap.remove(dst.getId());
        openMapQueue.remove(best);
    }
    int fcost = cost;
    if (sh != null && dst.getTile() != null) {
        fcost += sh.getValue(dst.getTile());
    }
    f.put(dst.getId(), fcost);
    openMap.put(dst.getId(), path);
    openMapQueue.offer(path);
}
 
開發者ID:wintertime,項目名稱:FreeCol,代碼行數:26,代碼來源:Map.java

示例6: updateProxyPool

import java.util.PriorityQueue; //導入方法依賴的package包/類
public void updateProxyPool() {
    PriorityQueue<HttpProxy> temp = new PriorityQueue<>(poolSize);
    addressSet.clear();
    while (proxies.size() > updateThreshold) {
        addressSet.add(proxies.peek().address);
        temp.offer(proxies.poll());
    }
    proxies.clear();
    proxies = temp;
    this.fill(HttpProxyCollector.getProxyIps(strategy, (poolSize - temp.size()) * 2));
}
 
開發者ID:ZhangJiupeng,項目名稱:Gospy,代碼行數:12,代碼來源:HttpProxyManager.java

示例7: getSortedTimestamps

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Gets the sorted timestamps of any buffered events.
 *
 * @return a sorted list of timestamps that have at least one buffered event.
 */
private PriorityQueue<Long> getSortedTimestamps() throws Exception {
    PriorityQueue<Long> sortedTimestamps = new PriorityQueue<>();
    for (Long timestamp : elementQueueState.keys()) {
        sortedTimestamps.offer(timestamp);
    }
    return sortedTimestamps;
}
 
開發者ID:pravega,項目名稱:flink-connectors,代碼行數:13,代碼來源:EventTimeOrderingOperator.java

示例8: add

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Add this candidate to the open map+queue.
 *
 * @param openMap The list of available nodes.
 * @param openMapQueue The queue of available nodes.
 * @param cost The provisional cost for the path.
 * @param sh A {@code SearchHeuristic} to apply.
 */
public void add(HashMap<String, PathNode> openMap,
                PriorityQueue<PathNode> openMapQueue,
                HashMap<String, Integer> f,
                SearchHeuristic sh) {
    int fcost = this.cost;
    if (this.dst.getTile() != null) {
        fcost += sh.getValue(this.dst.getTile());
    }
    f.put(this.dst.getId(), fcost);
    PathNode path = new PathNode(this.dst, this.movesLeft, this.turns,
        this.onCarrier, this.current, null);
    openMap.put(this.dst.getId(), path);
    openMapQueue.offer(path);
}
 
開發者ID:FreeCol,項目名稱:freecol,代碼行數:23,代碼來源:Map.java

示例9: nextGeneration

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Advances the current population to the next generation. All objects are cloned during
 * the process.
 */
@SuppressWarnings("unchecked")
public void nextGeneration() {
	PriorityQueue<T> newPopulation = new PriorityQueue<T>(getPopulationSize(), new FitnessComparator());

	//Take best n and copy into new population
	newPopulation.addAll(getTopN(config.getNumElite()));

	int fitnessSum = getFitnessSum();
	
	while (newPopulation.size() < config.getPopulationSize()) {
		T mommy = getWeightedOrganism(fitnessSum);
		T daddy = getWeightedOrganism(fitnessSum);
		
		T offspring = mommy;
		if (shouldCrossover()) {
			offspring = (T) mommy.breed(daddy);
		}
		
		if (shouldMutate()) {
			offspring = (T) offspring.mutate();
		}
		newPopulation.offer(offspring);
	}
	
	generation++;
	population = newPopulation;
}
 
開發者ID:ryantate314,項目名稱:genetic-one-tough-puzzle-solver,代碼行數:32,代碼來源:Ecosystem.java

示例10: testOfferNull

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * offer(null) throws NPE
 */
public void testOfferNull() {
    PriorityQueue q = new PriorityQueue(1);
    try {
        q.offer(null);
        shouldThrow();
    } catch (NullPointerException success) {}
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:11,代碼來源:PriorityQueueTest.java

示例11: testOfferNonComparable

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Offer of non-Comparable throws CCE
 */
public void testOfferNonComparable() {
    PriorityQueue q = new PriorityQueue(1);
    try {
        q.offer(new Object());
        shouldThrow();
    } catch (ClassCastException success) {
        assertTrue(q.isEmpty());
        assertEquals(0, q.size());
        assertNull(q.poll());
    }
}
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:15,代碼來源:PriorityQueueTest.java

示例12: computeCOF

import java.util.PriorityQueue; //導入方法依賴的package包/類
public void computeCOF(ArrayList<COFObject> cofobjectList, int k, DistanceMeasure measure) {

		// define a list of knn for each cof object
		PriorityQueue<COFKnn> knnList = new PriorityQueue<COFKnn>();

		// reset pcl, kDist, and deviation
		double pcl = 0.0;
		double kDist = 0.0;
		double deviation = 0.0;

		for (COFObject cofobject : cofobjectList) {// for all objects in the dataset
			double distance = Double.POSITIVE_INFINITY;
			// compute the distance to current object
			distance = measure.calculateDistance(this.getValues(), cofobject.getValues());
			COFKnn cOFKnn = new COFKnn(cofobject, distance);
			// determine if cofobject is on of the nearest neighbors to current object
			if (knnList.size() < k) {
				knnList.offer(cOFKnn);
			} else if (distance < knnList.peek().getDistance()) {
				knnList.remove();
				knnList.offer(cOFKnn);
			}
			// if the cofobject has the same class label, add its distance to deviation
			if (this.getLabel() == cofobject.getLabel()) {
				deviation += distance;
			}

		}
		this.setDeviation(deviation); // save deviation

		// compute pcl to current object
		for (COFKnn cofKnn : knnList) {
			kDist += measure.calculateDistance(getValues(), cofKnn.getCofobject().getValues());
			if (this.getLabel() == cofKnn.getCofobject().getLabel()) {
				pcl++;
			}
		}

		this.setPcl(pcl); // save pcl
		this.setCOF(pcl); // save the initial cof based on pcl
		this.setKDist(kDist); // save kDist

	}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:44,代碼來源:COFObject.java


注:本文中的java.util.PriorityQueue.offer方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。