寻找发帖水王

是如下的扩展。
http://blog.csdn.net/xiaoding133/article/details/8035183


若size个发帖很多的ID,他们的发帖数目都超过了帖子总数目N的1/size,怎么从发贴的ID中快速找出他们的ID?

package com.chruan.test.algo;
/**
 * 寻找发帖水王
 * @author Chruan
 * @version v1.0
 * @date Oct 10, 2012
 */
public class Tango {

	public static void main(String[] args) {
		int a[] = {0,4,1,4,0,4,1,4,1,0,3,3,0,3,3,3}; 
		calTango(a,3);
	}
	/**
	 * 若size个发帖很多的ID,他们的发帖数目都超过了帖子总数目N的1/size,怎么从发贴的ID中快速找出他们的ID?
	 * @param id 发贴的id列表
	 * @param size 
	 */
	public static void calTango(int[] id, int size){
		int[] candidates=new int[size];
		int[] times = new int[size];
		for (int idx=0;idx<size;idx++)
			times[idx]=0;
		boolean find = false;
		for (int idx=0;idx<id.length;idx++){
			//有空位就入座
			for(int i=0;i<size;i++)
				if (times[i]==0){
					times[i]++;
					find = true;
					candidates[i]=id[idx];
					break;
				}
			//没有空位
			if (!find){
				//是否已经入座,即座中有一样的id
				for(int i=0;i<size;i++){
					if (candidates[i]==id[idx]){
						times[i]++;
						find = true;
						break;
					}
				}
				//没有一样的,就都减1,即消去。
				if (!find)
					for (int i=0;i<size;i++){
						times[i]--;
					}
			}
		}
		
		//输出
		for (int i=0;i<size;i++)
		{
//			if (times[i]>0)
			System.out.println(times[i] +" "+candidates[i]);
		}
	}
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值