腾讯2018春招技术类编程题3

既然不能解决眼前的苟且,就先把诗和远方放一放!加油吧,我的喵小姐!


3、贪吃的小Q

审题:1)每天至少吃一块巧克力,所以第一天最多吃M-(N-1);
2)从M-(N-1)开始遍历,找到满足条件的吃法。
 

import java.util.Scanner;

public class Main {

	public static void main(String[] args) {
		Scanner sc=new Scanner(System.in);
		int n=sc.nextInt();//出差天数
		int m=sc.nextInt();//巧克力总数
		int i,j;//i遍历第一天吃巧克力的块数;j遍历时间
		int sum,next,now;
	    for(i=m-n+1;i>=1;i--){
	    	sum=i;
	    	next=i;	    	
	    	j=1;
	    	while(j<n){
	    		if(next<2){
	    			now=1;//下一天吃的巧克力数
	    		}else{
	    			now=next/2+next%2;
	    		}
	    		sum += now;
		        if (sum > m)
		        {
		           break;
		        }
		        next = now;
		        j++;
		    }
		    if (j == n)
		    {
		       break;
		    }
	    }
	    System.out.println(i);
	}	  			
}

下次换二分查找实现一次,今天的任务把上次的任务:所有的排序算法整理一次

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值