poj_2533_Longest Ordered Su... poj_1260_Pearls hdu_1025_Constructing Roa... poj_2533_Longest Ordered

/*

标题不能太长,所以写这了

poj_2533_Longest Ordered Subsequence poj_1260_Pearls hdu_1025_Constructing Roads In JGShining‘s King hdu_1074_Doing Homework

*/

poj_2533_Longest Ordered Subsequence

http://poj.org/problem?id=2533

LIS 不解释 ==

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

int main(){
	int n;
	cin>>n;
	int a[1010];
	int dp[1010];
	for (int i=0;i<n;i++){
		cin>>a[i];
	}
	int ans=1;
	for (int i=0;i<n;i++){
		dp[i]=1;
		for (int j=0;j<i;j++){
			if(a[i]>a[j]){
				dp[i]=max(dp[i],dp[j]+1);
			}
		}
		ans=max(ans,dp[i]);
	}
	cout<<ans<<endl;
}

poj_1260_Pearls

http://poj.org/problem?id=1260

有n种珍珠,价额越高,质量越好,购买时每种应付款(数量+10)*单价;

原计划n种珍珠,第i种买ai颗,价格pi;(价p i>p i-1)

现在需要求换种方案,使得购买的数量不变,且质量更好,总价更小,求总价。

价格更少的关键在于那个“+10”,

此外,替换珍珠是连续的一个段,如果第i+2种珍珠可以用来替换第i种,那么第i+1应该更便意。

so dp[i] = min ( dp[i] , dp[j] +(sum[i] - sum[j] + 10) * p[i] );

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;

const int INF=999999999;

struct Node {
	int a,p;
}node[106];

bool cmp (Node a,Node b){
	return  a.p<b.p;
}

int main(){
    int c;
    cin>>c;
    while (c--){
        int n,sum=0;
        int dp[106];
        int s[106];
        dp[0]=0;s[0]=0;
        cin>>n;
        for (int i=1;i<=n;i++){
            cin>>node[i].a>>node[i].p;
            sum+=(node[i].a+10)*node[i].p;
            s[i]=s[i-1]+node[i].a;
        }
        sort(node,node+n,cmp);
        for (int i=1;i<=n;i++){
        	dp[i]=INF;
            for (int j=0;j<=i-1;j++){
            	dp[i]=min(dp[i],dp[j]+(s[i]-s[j]+10)*node[i].p);
            }
            // cout<<dp[i]<<" ";
        }
        cout<<dp[n]<<endl;
    }
    return 0;
}

hdu_1025_Constructing Roads In JGShining‘s King

http://acm.hdu.edu.cn/showproblem.php?pid=1025

平行线上有一些城市,一边是富饶的,一边是贫困的。没坐父老的城市拥有一种资源,对应着有一座贫困的城市缺少改资源。

现在The King 希望修通富饶城市和贫困城市之间的马路来帮助他们(资源的拥有和缺少必须对应),但为了防止交通事故,不允许两条道路相交叉。

问最多修多少道路。

以贫困城市为数组下标,富饶城市为数组元素的值,求 LIS 。

==  题目好坑,O(nlogn)的方法猜不会TLE,(copy自白书)而且,road和roads啊啊啊啊啊==

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;

int n;

const int INF=999999999;

int dp[500050];

int main(){
    int c(0);
    char road[2][10]={"road","roads"};
    while (scanf("%d",&n)!=EOF){
        int a[500050];
        for (int i=0;i<n;i++){
            int x,y;
            scanf ("%d%d",&x,&y);
            a[x-1]=y;
        }
        fill (dp,dp+n,INF);
        for (int i=0;i<n;i++){
            *lower_bound(dp,dp+n,a[i])=a[i];
        }
        int ans=lower_bound(dp,dp+n,INF)-dp;;
        printf ("Case %d:\nMy king, at most %d %s can be built.\n",++c,ans,road[ans!=1?1:0]);
    }
    return 0;
}

hdu_1074_Doing Homework

http://acm.hdu.edu.cn/showproblem.php?pid=1074

给出n份作业的截止时间第 D 天和需要花费时间 C 天,没迟交一天扣一分。

开这题好几天了,一直没思路,虽然知道是状压dp,知道今天中午吃饭的时候才来灵感,用一维的dp。T^T,一直在想二维的。

把n份作业的做与没做压缩成一个二进制的 int 。第i位表示第i份作业有没有做。

如果s表示做完的集合,那么他可以由 {s}-{j} V {j} 得到。

dp[s] = min( dp[s-(1<<j)] + s); ( s : 做第j份作业要罚的分,s = max( t[s] + Cs - Ds , 0 ) );

路径还原:fa 数组记录由状态 fa[ i ]得到状态 i ;还原是用位运算加递归;

#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
using namespace std;

#define INF 999999999

struct Work {
	string s;
	int d,c;
}w[16];

struct Node{
	int p,t;
};

int  fa[1<<15+6];
Node dp[1<<15+6];

void findway (int a,int b){
	int c=a-b;
	int k=0;
	while(c!=1){
		c>>=1;
		k++;
	}
	cout<<w[k].s<<endl;
}

void find (int f,int k){
	if (f!=k){
		find (fa[f],f);
		findway(k,f);
	}
}

int main(){
	int c;
	cin>>c;
	while (c--){
		int n;
		scanf("%d",&n);
		for (int i=0;i<n;i++){
			cin>>w[i].s>>w[i].d>>w[i].c;
		}
		for (int i=0;i<(1<<n);i++){
			dp[i].p=INF;dp[i].t=0;
			fa[i]=i;
		}
		dp[0].p=0;
		for (int i=1;i<(1<<n);i++){
			for (int j=0;j<n;j++){
				if (i&(1<<j)){
					int s;
					s=max(dp[i-(1<<j)].t+w[j].c-w[j].d,0);
					if(dp[i].p>=dp[i-(1<<j)].p+s){
						dp[i].p=dp[i-(1<<j)].p+s;
						fa[i]=i-(1<<j);
					}
					dp[i].t=dp[i-(1<<j)].t+w[j].c;
				}
			}
		}
		printf ("%d\n",dp[(1<<n)-1]);
		int k=(1<<n)-1;
		find(fa[k],k);
	}
	return 0;
}

dp水我水的好欢快啊~啊。

时间: 2024-10-13 16:42:09

poj_2533_Longest Ordered Su... poj_1260_Pearls hdu_1025_Constructing Roa... poj_2533_Longest Ordered的相关文章

c++  与  java  中的 继承

C++ 代码: #include <iostream> #include <string> using namespace std; class Parent { public: void fun() {cout<<"Parent fun"<<endl;} void fun(int a) {cout<<"Parent fun int a"<<endl;} void fun(int a, int

python 学习第八课 -- 异常 反射 socket

面向对象 相关 一.isinstance(obj,cls)  查看obj是否为cls的对象 issubclass(sub,super) 查看类sub是否为super的派生类 二. 异常处理 1.   异常基础 try: pass except Exception,e: print e e为Exception的对象,print e 就是print Exception中的__str__ 2.   异常种类 常用异常 AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo

自写函数VB6 STUFF函数 和 VB.net 2010 STUFF函数 详解

'*************************************************************************'**模 块 名:自写函数VB6 STUFF函数 和 VB.net 2010 STUFF函数 详解'**说    明:蓝凤凰设计商城 浴火凤凰-郭卫 | 蓝凤凰-魔灵 | 郭卫-icecept'**创 建 人:浴火凤凰-郭卫'**日    期:2015年10月10日  23:13:55'**修 改 人:浴火凤凰-郭卫'**日    期:'**描   

lind 语 api 数据的安全性  第四弹

web api的安全性怎么保证呢. 一般公司会自己封装一套请求的规范. 下面来看看lind语里的webapi安全规范 step one 先看下 diagram: 学而思: 从上面的图分析一下: 如果我们的webapi开放给第三方的平台那么:这里的规范是否适用呢. 思考一下. 成为习惯 step tow .... 我们来看下代码: 注意 我们是因为里面又两个:一个 是 看 的我 .一个是 学的我.一个是思的我. 所以 这里是有三个我 看我曰:我去翻码.

TCP 和 UDP 编程 —— Android

参考了<深入理解Android网络编程>这本书 我们都知道TCP和UDP最大的区别就是,TCP是面向连接的,而UDP是无连接的. 那么使用TCP和UDP编程,事实上差别也是在这里: 1.使用TCP通讯: 分为客户端和服务器,主要是先初始化,像IP,端口这些肯定要先绑定的,服务器等待客户端连接,连接之后,通过流进行数据的收发. A.首先是服务器端: 步骤1:初始化——ServerSocket serverCocket = null://创建一个ServerSocket对象 serverCocke

Linux 内存 virt res shr data swap 意义

virt  res shr data 这几个很容易搞混了,写一下 首先解释下含义: virt : 程序占用的虚拟内存 man: The total amount of virtual memory used by the task. It includes all code, data and shared libraries plus pages that have been swapped out and pages that have been mapped but not used. r

HDU 1025 Constructing Roads In JGShining&#39;s Kingdom   LIS 简单题 好题 超级坑

Constructing Roads In JGShining's Kingdom Problem Description JGShining's kingdom consists of 2n(n is no more than 500,000) small cities which are located in two parallel lines. Half of these cities are rich in resource (we call them rich cities) whi

Centos6.5 配置  DRBD8.4.3

废话不多说,现在开始: 1.2台虚拟机,Centos6.5系统,系统配置啥的都一样,能互相ping 通.把它们称为A和B. 2. A: server iptables stop setenforce 1                 //先把这2台服务器的防火墙和SELINUX关闭. ------------------------------------------- B: server iptables stop setenforce 1                 //先把这2台服务

《程序员的职业修养》读后感(二):说"不" and 说“是”

简介:"能就是能,不能就是不能,不要说'试试看'."另一方面,作为一个初入行业的程序员,我们有没有权利,应不应该说不(或是)呢,又该何时何地何事说"不(或是)"?这篇文章就解决此问题. 相信工作的人对此都会很有感触,当老板交给我们一个任务时,不管是对自己能力的不清楚认识,还是迫于老板的"淫威",大家貌似好像都不敢说一句能或者不能,总是选择一个折中的答案:我去试试看.可是这样的话语给老板的潜意识意思就是你可以完成,但是在你这里,这句话的潜意思就是我也很可能完不成.所以