uva 607 Scheduling Lectures

你在一所学校教书,每节课时长L,你有n个主题必须要讲完,每个主题时常为ti。

有两个限制:1,每个主题只能在一节课内讲完,不能分开在多节课;2,必须按主题顺序讲,不能打乱。

对于每节课,讲完主题的内容会剩下时间t,如果t>10,会产生不满意度(t-10)^2,如果 1<=t<=10, 学生很高兴,所以产生不满意度是负数的-C,如果t=0, 那么不满意度为0.

问讲完所有主题,最少要用多少节课?如果有多种方案,要求不满意度最低。

num[i]表示讲完第i个主题,所用的最少节课

dp[i]表示讲完i个主题,用了num[i]节课的最低不满意度

//  Created by Chenhongwei in 2015.
//  Copyright (c) 2015 Chenhongwei. All rights reserved.

#include"iostream"
#include"cstdio"
#include"cstdlib"
#include"cstring"
#include"climits"
#include"queue"
#include"cmath"
#include"map"
#include"set"
#include"stack"
#include"vector"
#include"sstream"
#include"algorithm"
using namespace std;
typedef long long ll;
const int inf=2e9;
int n,l,c;
int sum[1010];
int num[1010],dp[1010];
int penalty(int x)
{
	if(x==0)
		return 0;
	else if(x>=1&&x<=10)
		return -c;
	else 
		return (x-10)*(x-10); 
}
int main()
{	
	//ios::sync_with_stdio(false);
	// freopen("in.txt","r",stdin);
	//freopen("out.txt","w",stdout);
	int Case=0;
	while(scanf("%d",&n)&&n)
	{
		if(Case)
			cout<<endl;
		Case++;
		cout<<"Case "<<Case<<':'<<endl;
		scanf("%d%d",&l,&c);
		sum[0]=0;
		int tmp;
		for(int i=1;i<=n;i++)
			scanf("%d",&tmp),sum[i]=sum[i-1]+tmp;
		num[0]=dp[0]=0;
		for(int i=1;i<=n;i++)
		{
			num[i]=dp[i]=inf;
			for(int j=0;j<i;j++)
				if(l>=sum[i]-sum[j])
				{
					if(num[i]>num[j]+1)
					{
						num[i]=num[j]+1;
						dp[i]=dp[j]+penalty(l-(sum[i]-sum[j]));
					}
					else if(num[i]==num[j]+1)
						if(dp[i]>dp[j]+penalty(l-(sum[i]-sum[j])))
							dp[i]=dp[j]+penalty(l-(sum[i]-sum[j]));
				}
		}
		cout<<"Minimum number of lectures: "<<num[n]<<endl;
		cout<<"Total dissatisfaction index: "<<dp[n]<<endl;

	}
	return 0;
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值