poj 1157 LITTLE SHOP OF FLOWERS

/*

题意: 有n束花和m个花瓶,一束花 i 插在一个花瓶 j 中都有一个对应的美观值 A[i][j],
现在要将这n束花全部插入花瓶中并使得所有的花的美观值最大,求该最大值.
题目规定若i<j,则第i束花必须出现在第j束花之前,
设 ans[i,j] 为前 i 束花插在前 j 个花瓶中的最大美学值,
则有状态转移方程:ans[i,j]=max(ans[i-1,k-1]+A[i,k]),其中i<=k<=j,
A[i,k] 为第 i 束花插在第 k 个花瓶中的美学值,规定ans[0,j]=0,0<=j<=m

*/


#include <iostream> //DP
using namespace std;

int A[105][105],ans[105][105];
#define MIN INT_MIN
int dp(int i,int j) // 求前 i 束花插在前 j 个花瓶中的最大美学值ans[i][j]
{

if(ans[i][j]!=MIN) // 说明ans[i][j]已求解
return ans[i][j];

int t=MIN;
for(int k=i;k<=j;++k)
{
if(dp(i-1,k-1)+A[i][k]>t)
t=dp(i-1,k-1)+A[i][k];
}
ans[i][j]=t;
return ans[i][j];
}
int main()
{
int n,m; //n束花,m个花瓶
cin>>n>>m;

for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
cin>>A[i][j];
fill(&ans[1][1],&ans[n+1][m+1],MIN);
for(int j=0;j<=m;++j)
ans[0][j]=0;
cout<<dp(n,m)<<endl;
return 0;
}

转载于:https://www.cnblogs.com/mjc467621163/archive/2011/07/22/2114272.html

OFDM(正交频分复用)是一种高效的多载波通信技术,它将高速数据流拆分为多个低速子流,并通过多个并行的低带宽子载波传输。这种技术具有高频谱效率、强抗多径衰落能力灵活的带宽分配优势。 OFDM系统利用大量正交子载波传输数据,子载波间的正交性可有效避免码间干扰(ISI)。其数学表达为多个离散子载波信号的线性组合,调制解调过程通过FFT(快速傅立叶变换)IFFT(逆快速傅立叶变换)实。其关键流程包括:数据符号映射到子载波、IFFT转换为时域信号、添加循环前缀以减少ISI、信道传输、接收端FFT恢复子载波数据解调原始数据。 Matlab是一种广泛应用于科研、工程数据分析的高级编程语言交互式环境。在OFDM系统设计中,首先需掌握Matlab基础,包括编程语法、函数库工具箱。接着,根据OFDM原理构建系统模型,实IFFT/FFT变换、循环前缀处理信道建模等关键算法,并通过改变参数(如信噪比、调制方式)评估系统性能。最后,利用Matlab的绘图功能展示仿真结果,如误码率(BER)曲线等。 无线通信中主要考虑加性高斯白噪声(AWGN),其在频带上均匀分布且统计独立。通过仿真OFDM系统,可在不同信噪比下测量并绘制BER曲线。分析重点包括:不同调制方式(如BPSK、QPSK)对BER的影响、循环前缀长度选择对性能的影响以及信道估计误差对BER的影响。 OFDM技术广泛应用于多个领域,如数字音频广播(DAB)、地面数字电视广播(DVB-T)、无线局域网(WLAN)以及4G/LTE5G移动通信,是这些通信标准中的核心技术之一。 深入研究基于Matlab的OFDM系统设计与仿真,有助于加深对OFDM技术的理解,并提升解决实际通信问题的能力。仿真得到的关键性能指标(如BER曲线)对评估系统可靠性至关重要。未来可进一步探索复杂信道条件下的OFDM性能及系统优化,以适应不同应用场景
51单片机是电子工程领域常用的入门级微控制器,广泛应用于小型电子设备,例如电子时钟。本项目将介绍如何利用51单片机设计一款简单的电子时钟,并通过Keil软件进行程序开发,同时借助Proteus仿真工具进行电路模拟,帮助初学者掌握51单片机的基础应用。 51单片机基于Intel 8051内核,集成了CPU、RAM、ROM、定时器/计数器I/O端口等功能模块,具有易于编程性价比高的优势。在电子时钟项目中,主要利用其定时器实时间的精确计算。Keil μVision是51单片机的常用开发环境,支持C语言汇编语言编程。开发时,需编写代码以控制单片机显示更新时间,包括初始化时钟硬件、设置定时器中断、编写中断服务程序以及与LCD显示屏交互等步骤。关键环节如下:一是初始化,配置时钟源(如外部晶振)设定工作频率;二是定时器设置,选择合适模式(如模式1或模式2),设置计数初以获得所需时间分辨率;三是中断服务,编写定时器中断服务程序,定时器溢出时更新时间并触发中断;四是显示控制,通过I/O端口驱动LCD显示屏显示当前时间。 Proteus是一款虚拟原型设计软件,可用于模拟硬件电路,帮助开发者在编程前验证电路设计。在Proteus中,可搭建51单片机、LCD模块、晶振及电阻、电容等元件,形成电子时钟电路模型。运行仿真后,可观察程序在实际电路中的运行情况,及时发并解决问题。 实际项目中,51单片机电子时钟还涉及以下知识点:一是时钟信号产生,定时器通过计数外部时钟脉冲实时间累计,可通过调整晶振频率定时器初始设置不同时间间隔;二是LCD接口,需理解LCD的命令数据传输协议,以及如何控制背光、显示模式、行列地址等;三是中断系统,了解中断概念、中断向量及程序中中断的启用禁用方法;四是数码管显示,若使用数码管而非LCD,需了解其显示原理及段选、位选的驱动方式。 本项目融合了单片机基础、
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值