【leetcode】68.(Hard) Text Justification

题目链接



提交代码:

class Solution {
    public List<String> fullJustify(String[] words, int maxWidth) {
    	List<String> res=new ArrayList<String>();
    	int startIndex=0,endIndex=0,curWidth;
    	
    	while(endIndex<words.length) {
    		curWidth=0;
    		curWidth+=words[endIndex].length();
    		endIndex++;
    		
    		while(endIndex<words.length&&
    				curWidth+words[endIndex].length()<maxWidth) {
    			curWidth+=(words[endIndex].length()+1);   //at least one space
    			endIndex++;
    		}
    		addString(startIndex,endIndex,words,maxWidth,res);
    		startIndex=endIndex;
    		endIndex=startIndex;
    	}
    	
    	return res;
    }
    
    public void addString(int startIndex,int endIndex,String[] words,
    		int maxWidth,List<String> res) {
    	if((endIndex-startIndex)==1) {
    		//with one word in a line 
    		String str="";
    		str+=words[startIndex];
    		
    		for(int i=0;i<maxWidth-words[startIndex].length();i++)
    			str+=" ";
    		
    		res.add(str);
    		return;
    	}else if(endIndex==words.length) {
    		//the last line should be left-justified
    		int totalSpaceWidth=maxWidth;
    		String str="";
    		str+=words[startIndex];
    		totalSpaceWidth-=words[startIndex].length();
    		
    		for(int i=startIndex+1;i<endIndex;i++) {
    			str+=" ";
    			str+=words[i];
    			totalSpaceWidth-=words[i].length();
    		}
    		
    		for(int i=0;i<(totalSpaceWidth-(endIndex-startIndex-1));i++)
    				str+=" ";
    				
    		res.add(str);
    		return;
    	}else {
    		//general situation
    	int curWidth=0,remainSpaceWidth,spaceWidth;
    	int spaceCnt=endIndex-startIndex-1;
    	for(int i=startIndex;i<endIndex;i++)
    		curWidth+=words[i].length();
    	remainSpaceWidth=maxWidth-curWidth;

    	String str="";
    	str+=words[startIndex];
    	
    	for(int i=startIndex+1;i<endIndex;i++) {
    		spaceWidth=(int) Math.ceil((double)remainSpaceWidth/(spaceCnt--));
    		for(int j=0;j<spaceWidth;j++)
    			str+=" ";
    		str+=words[i];
    		remainSpaceWidth-=spaceWidth;
    	}
    		res.add(str);
    	}
    }
}

运行结果:
在这里插入图片描述

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值