📘
Introduction_to_Algorithms
  • Introduction
  • 第6章:堆排序
    • 练习题
    • 思考题
      • 6-3 Young
  • 第7章:快速排序
    • 练习题
    • 思考题
      • 7-6 对区间的模糊排序
  • 第8章:线性时间排序
    • 练习题
      • 8.3-4 O(n)时间内对[0..n^-1]之间的n个数排序
    • 思考题
      • 8-3 排序不同长度的数据项
  • 第9章 排序和顺序统计学算法导论
    • 练习题
      • 9.1-1
      • 9.3-3 快速排序-最坏时间O(nlgn)
      • 9.3-6 nlgk时间求k分位数
      • 9.3-8 求两个数组的中位数
    • 思考题
      • 9-2-c-带权中位数
  • 第10章:栈和队列
    • 10.1 栈和队列
      • 练习题
      • 10.1-2 用一个数组实现两个栈
      • 10.1-5 双端队列
    • 10.2 链表
      • 练习题
      • 10.2-5 环形链表实现字典操作INSERT、DELETE、SEARCH
    • 10.3 指针和对象实现
      • 练习题
      • 10.3-4 紧凑的多重数组
    • 思考题
  • 第11章 散列表
  • [第12章]
    • [笔记和代码]
      • 12-2 基数树
  • 第14章
    • 笔记和代码
      • 14.3-6 MIN GAP
  • 第15章:动态规划
    • 练习题
    • 思考题
      • 15-2 整齐打印
      • 15-3 编辑距离
  • 第20章:斐波那契堆
    • 练习题
    • 思考题
  • ACM解题报告
    • 1043 八数码问题
    • 1053 Entropy
    • 1114 Piggy-Bank 完全背包
    • 1133 catalan数二维变种
    • 1166 敌兵布阵
    • 1281 棋盘游戏 二分匹配与增广链
    • 1394 Minimum Inversion Number
    • 1394 用线段树求逆序数
    • 1787 欧拉函数之在线算法
    • 2438 三分查找
    • 2473 Junk-Mail Filter 并查集的删除
    • 2824 欧拉公式之打表算法
    • 2855 Fibonacci Check-up 矩阵的应用
    • 2642 Stars 二维树状数组
    • 2888 二维RMQ
    • 3033 分组背包之每组至少选一
    • 3307 A^B = C mod D,已知A,C,D,求解B
    • 3465 Life is a Line 用归并排序求逆序数
    • 3483 A Very Simple Problem 数论+矩阵的应用
    • 3518 后缀数组
    • 3579 中国剩余定理(ACM/不互质的情况)
    • 后缀数组
    • B-树
    • 排序算法总结
Powered by GitBook
On this page
  • include
  • include
  • define M 10//一行的最大长度
  • define N 10//单词的个数
  1. 第15章:动态规划
  2. 思考题

15-2 整齐打印

Previous思考题Next15-3 编辑距离

Last updated 5 years ago

题目:

思考: 定义 (1)extra为行末多余空格字符个数的立方和 (2)f[i,j] = M - j + i - SUM(lk) , i<=k<=j (3)令len[i,j]表示第i个单词到第j个单词可以得到的最小extra 整齐打印问题可以分解成以下子问题 (1)若f[i,j] < 0,,则len[i,j] = MIN(len[i,k] + len[k+1,j]) , i<=k 0 && j==n,则len[i,j] = 0 (3)若i==j,则len[i,j] = (f[i,j])^3 代码:为了编程方便,程序和说明略有不同

include

include

using namespace std;

define M 10//一行的最大长度

define N 10//单词的个数

int s[N][N];

void DP(int len) { int i, j, k, step, temp; for(step = 0; step < N; step++) { for(i = 0; i < N; i++) { temp = 0;j = i + step; if(j >= N) break; //计算len[i,j] for(k = i; k <= j; k++) { if(k != i) temp++; temp = temp + len[k]; if(temp > M) break; } if(temp > M)s[i][j] = 0x7fffffff; //若f[i,j] > 0 && j==n,则len[i,j] = 0 else if(j == N-1)s[i][j] = 0; //若i==j,则len[i,j] = (f[i,j])^3 else s[i][j] = pow(M1.0-temp,3); //若f[i,j] < 0,,则len[i,j] = MIN(len[i,k] + len[k+1,j]) , i<=k<j for(k = i; k < j; k++) if(s[i][k]+s[k+1][j] < s[i][j]) s[i][j] = s[i][k]+s[k+1][j]; } } cout<<s[0][N-1]<<endl; } void Print() { int i, j; for(i = 0; i < N; i++) { for(j = 0; j < N; j++) cout<<s[i][j]<<' '; cout<<endl; } } /1 2 3 1 2 3 1 2 3 1/ int main() { int len[N], i; //输出数据 for(i = 0; i < N; i++) cin>>len[i]; DP(len); // Print(); return 0; }