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


Java PriorityQueue.size方法代碼示例

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


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

示例1: 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

示例2: getTopN

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Get top N elements
 *
 * @param vec the vec to extract the top elements from
 * @param N the number of elements to extract
 * @return the indices and the sorted top N elements
 */
private List<Double> getTopN(INDArray vec, int N) {
  BasicModelUtils.ArrayComparator comparator = new BasicModelUtils.ArrayComparator();
  PriorityQueue<Double[]> queue = new PriorityQueue<>(vec.rows(), comparator);

  for (int j = 0; j < vec.length(); j++) {
    final Double[] pair = new Double[] {vec.getDouble(j), (double) j};
    if (queue.size() < N) {
      queue.add(pair);
    } else {
      Double[] head = queue.peek();
      if (comparator.compare(pair, head) > 0) {
        queue.poll();
        queue.add(pair);
      }
    }
  }

  List<Double> lowToHighSimLst = new ArrayList<>();

  while (!queue.isEmpty()) {
    double ind = queue.poll()[1];
    lowToHighSimLst.add(ind);
  }
  return Lists.reverse(lowToHighSimLst);
}
 
開發者ID:tteofili,項目名稱:par2hier,代碼行數:33,代碼來源:Par2Hier.java

示例3: test1

import java.util.PriorityQueue; //導入方法依賴的package包/類
@Test public void test1() {
  int[] a = new int[]{1000,900,8,7,3,2,1,90000};
  int n=5;
  PriorityQueue<Integer> q = new PriorityQueue<>(n, new Comparator<Integer>() {
    @Override public int compare(Integer o1, Integer o2) {
      return o2-o1;
    }
  });

  for(int i: a) {
    if( q.size() < n ) q.add(i);
    else {
      if( i < q.peek() ) {
        q.poll();
        q.add(i);
      }
    }
  }

  while(!q.isEmpty()) {
    System.out.println(q.poll());
  }
}
 
開發者ID:spennihana,項目名稱:FasterWordEmbeddings,代碼行數:24,代碼來源:TopNTest.java

示例4: CalculateBaseLine

import java.util.PriorityQueue; //導入方法依賴的package包/類
private void CalculateBaseLine() {
    _baseLine = 0f;
    PriorityQueue<Float> IntensityQueue = new PriorityQueue<>();
    for (XYData point : SmoothData.Data) {
        IntensityQueue.add(point.getY());
    }

    if (IntensityQueue.size() > 10) {
        for (int i = 0; i < IntensityQueue.size() / 10; i++) {
            _baseLine += IntensityQueue.poll();
        }
        _baseLine /= (IntensityQueue.size() / 10);
    } else {
        _baseLine = IntensityQueue.poll();
    }
}
 
開發者ID:YcheCourseProject,項目名稱:DIA-Umpire-Maven,代碼行數:17,代碼來源:PeakCurve.java

示例5: doLogistics

import java.util.PriorityQueue; //導入方法依賴的package包/類
private boolean doLogistics() {
    ItemStack item = drone.getInv().getStackInSlot(0);
    FluidStack fluid = drone.getTank().getFluid();
    PriorityQueue<LogisticsTask> tasks = manager.getTasks(item.isEmpty() ? fluid : item);
    if (tasks.size() > 0) {
        curTask = tasks.poll();
        return execute(curTask);
    }
    return false;
}
 
開發者ID:TeamPneumatic,項目名稱:pnc-repressurized,代碼行數:11,代碼來源:DroneAILogistics.java

示例6: 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

示例7: onTimer

import java.util.PriorityQueue; //導入方法依賴的package包/類
@Override
public void onTimer(long timestamp, OnTimerContext context,
    Collector<Tuple3<String, Long, String>> out) throws Exception {
  PriorityQueue<Tuple3<String, Long, String>> queue = queueState.value();
  Long watermark = context.timerService().currentWatermark();

  Tuple3<String, Long, String> head = queue.peek();
  boolean emitAll = queue.size() > MAX_NUMBER_OF_QUEUED_ELEMENTS;

  while (head != null && (head.f1 <= watermark || emitAll)) {
    out.collect(head);
    queue.remove(head);
    head = queue.peek();
  }
}
 
開發者ID:ehabqadah,項目名稱:in-situ-processing-datAcron,代碼行數:16,代碼來源:RawMessagesSorter.java

示例8: onTimer

import java.util.PriorityQueue; //導入方法依賴的package包/類
@Override
public void onTimer(long timestamp, OnTimerContext context, Collector<AisMessage> out)
    throws Exception {
  PriorityQueue<AisMessage> queue = queueState.value();
  Long watermark = context.timerService().currentWatermark();

  AisMessage head = queue.peek();
  boolean emitAll = queue.size() > MAX_NUMBER_OF_QUEUED_ELEMENTS;

  while (head != null && (head.timestamp <= watermark || emitAll)) {
    out.collect(head);
    queue.remove(head);
    head = queue.peek();
  }
}
 
開發者ID:ehabqadah,項目名稱:in-situ-processing-datAcron,代碼行數:16,代碼來源:AisMessagesStreamSorter.java

示例9: toIntArrayListReversed

import java.util.PriorityQueue; //導入方法依賴的package包/類
/**
 * Used in cases where a priority queue has been used to keep top K elements, and then its results are needed in descending order, 
 * in the form of an IntArrayList. The size of the results is equal to the size of the input.
 * @param <T> any subclass of ComparableIntFloatPair
 * @param pq
 * @return 
 */
public static <T extends ComparableIntFloatPair> IntArrayList toIntArrayListReversed(PriorityQueue<T> pq) {
    int i = pq.size();   
    int[] candidates = new int[i]; 
    while (!pq.isEmpty()) {
        T cand = pq.poll();
        candidates[--i] = cand.getEntityId(); //get pq elements in reverse order
    }
    return new IntArrayList(candidates);
}
 
開發者ID:vefthym,項目名稱:MinoanER,代碼行數:17,代碼來源:Utils.java

示例10: main

import java.util.PriorityQueue; //導入方法依賴的package包/類
@SuppressWarnings("Duplicates")
public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);

    PriorityQueue<Integer> minHeap = new PriorityQueue<>(10, Collections.reverseOrder());
    PriorityQueue<Integer> maxHeap = new PriorityQueue<>(10);

    int n = scanner.nextInt();

    for (int i = 0; i < n; i++) {
        int num = scanner.nextInt();

        if (minHeap.size() <= maxHeap.size()) {
            minHeap.add(num);
        } else {
            maxHeap.add(num);
        }

        while (!minHeap.isEmpty() && !maxHeap.isEmpty() && minHeap.peek() > maxHeap.peek()) {
            int min = minHeap.poll();
            int max = maxHeap.poll();

            minHeap.add(max);
            maxHeap.add(min);
        }

        double median = (minHeap.size() == maxHeap.size() ? ((minHeap.peek() + maxHeap.peek()) / 2.0) : minHeap.peek());

        System.out.println(median);
    }
}
 
開發者ID:viatsko,項目名稱:hack,代碼行數:32,代碼來源:HeapsFindTheRunningMedian.java

示例11: flatten

import java.util.PriorityQueue; //導入方法依賴的package包/類
public ClusterModel flatten(HierarchicalClusterModel model, ExampleSet exampleSet) throws OperatorException {
	HierarchicalClusterNode root = model.getRootNode();
	int numberOfClusters = getParameterAsInt(PARAMETER_NUMBER_OF_CLUSTER);

	// creating priorityQueue using reversing comparator
	PriorityQueue<HierarchicalClusterNode> queue = new PriorityQueue<HierarchicalClusterNode>(numberOfClusters,
			new Comparator<HierarchicalClusterNode>() {

		@Override
		public int compare(HierarchicalClusterNode o1, HierarchicalClusterNode o2) {
			int value = -1 * Double.compare(o1.getDistance(), o2.getDistance());
			if (value != 0) {
				return value;
			} else {
				return -1 * Double.compare(o1.getNumberOfExamplesInSubtree(), o2.getNumberOfExamplesInSubtree());
			}
		}
	});

	// Iteratively descend within graph by splitting at greatest node until queue is full or
	// enough leafs are collected
	LinkedList<HierarchicalClusterNode> leafs = new LinkedList<HierarchicalClusterNode>();
	queue.add(root);
	while (queue.size() < numberOfClusters - leafs.size()) {
		HierarchicalClusterNode topNode = queue.poll();
		if (topNode.getSubNodes().size() > 0) {
			queue.addAll(topNode.getSubNodes());
		} else {
			leafs.add(topNode);
		}
	}
	queue.addAll(leafs);

	// construct flat cluster model from nodes
	ClusterModel flatModel = new ClusterModel(exampleSet, numberOfClusters,
			getParameterAsBoolean(PARAMETER_ADD_AS_LABEL), getParameterAsBoolean(PARAMETER_REMOVE_UNLABELED));
	int i = 0;
	for (HierarchicalClusterNode node : queue) {
		Cluster flatCluster = flatModel.getCluster(i);
		for (Object exampleId : node.getExampleIdsInSubtree()) {
			flatCluster.assignExample(exampleId);
		}
		i++;
	}

	// delivering adapted example set
	if (exampleSetOutput.isConnected()) {
		exampleSetOutput.deliver(flatModel.apply((ExampleSet) exampleSet.clone()));
	}
	return flatModel;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:52,代碼來源:FlattenClusterModel.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.size方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。