Ex 6_9 某个字符串处理语言提供了一个将字符串一分为二的基本操作..._第六次作业

设字符串的长度为n,整型数组arr[0. . .n-1]的第一个数和最后一个数为开始点与结束点的位置,中间的数为拆分点的位置,设cost[i,j]为第i个分割点到第j个分割点的最小代价,两个分割点之间要有大于等于一个分割点才能把字符串继续拆分,因此j-i>=2; 得到递推式

package org.xiu68.ch06.ex6;
public class Ex6_9 {
public static void main(String[] args) {
// TODO Auto-generated method stub
//分割的最小代价为:30
//分割顺序为: 10 3
int[] arr=new int[]{1,3,10,20}; //设开始点为1和20,中间三个点为拆分点
int[][] splitPoint=new int[arr.length+1][arr.length+1];
minSplitCost(arr,splitPoint);
System.out.print("分割顺序为: ");
printSplitPoint(arr,splitPoint,1,arr.length);
System.out.println();
//分割的最小代价为:48
//分割顺序为: 10 8 2
int[] arr2=new int[]{1,2,8,10,30};
int[][] splitPoint2=new int[arr2.length+1][arr2.length+1];
minSplitCost(arr2,splitPoint2);
System.out.print("分割顺序为: ");
printSplitPoint(arr2,splitPoint2,1,arr2.length);
}
public static void minSplitCost(int[] arr,int[][] splitPoint){
int[][] cost=new int[arr.length+1][arr.length+1];
int length=arr.length;
for(int s=2;s<=length;s++){ //分割点的个数
for(int i=1;i<=length-s+1;i++){ //第一个分割点
int j=i+s-1; //最后一个分割点
if(j-i>=2) //两个分割点之间要有大于一个的分割点才能继续分割
cost[i][j]=Integer.MAX_VALUE;
for(int k=i+1;k<=j-1;k++){ //寻找分割子串最小代价对应的分割位置
int temp=cost[i][k]+cost[k][j]+arr[j-1]-arr[i-1]+1;
if(temp<cost[i][j]){
cost[i][j]=temp;
splitPoint[i][j]=k;
}
}//
}//
}//
System.out.println("分割的最小代价为:"+cost[1][length]);
}
public static void printSplitPoint(int[]arr,int[][] splitPoint,int i,int j){
if(j-i>=2){
System.out.print(arr[splitPoint[i][j]-1]+" ");
printSplitPoint(arr,splitPoint,i,splitPoint[i][j]);
printSplitPoint(arr,splitPoint,splitPoint[i][j],j);
}
}
}
Ex 6_9 某个字符串处理语言提供了一个将字符串一分为二的基本操作..._第六次作业的更多相关文章
- SQL Server获取下一个编码字符串的实现方案分割和进位
我在前一种解决方案SQL Server获取下一个编码字符实现和后一种解决方案SQL Server获取下一个编码字符实现继续重构与增强两篇博文中均提供了一种解决编码的方案,考虑良久对比以上两种方 ...
- Swift3.0语言教程比较、判断字符串
Swift3.0语言教程比较.判断字符串 Swift3.0语言教程比较.判断字符串,在一个程序中字符串很多时,常常会做的操作就是对这些字符串进行比较和判断.本小节将讲解这些内容. 1.不区分大小写比较 ...
- C语言提供了几个标准库函数 itoa() atoi()
C语言提供了几个标准库函数C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串.以下是用itoa()函数将整数转换为字符串的一个例子: # include <s ...
- 吴裕雄--天生自然C++语言学习笔记:C++ 字符串
C++ 提供了以下两种类型的字符串表示形式: C 风格字符串 C++ 引入的 string 类类型 C 风格的字符串起源于 C 语言,并在 C++ 中继续得到支持.字符串实际上是使用 null 字符 ...
- C语言程序设计(十) 字符串
第十章 字符串 字符串常量是由一对双引号括起来的一个字符串序列 字符串实际就是由若干个有效数字构成且以字符'\0'作为结束的一个字符序列 C语言没有提供字符串数据类型,因此字符串的存取要用字符型数组来 ...
- C语言中的字符和字符串
C语言在中常常出现字符和字符串,而一串字符或者字符串其实就是数组 字符数组的定义 char arr[]={'h','e','l','l','o','\0'}; 而定义字符串: char arr1[]= ...
- C语言提供的位运算符
运算符 含义 描述 & 按位与 如果两个相应的二进制位都为1,则该位的结果值为1,否则为0 | 按位或 两个相应的二进制位中只要有一个为1,该位的结果值为1 ^ 按位异或 若参加运算的两个 ...
- C语言基础:数组和字符串
数组:数组的定义注意点 数组初始化正确写法: int args[5] = {1,23,32,4,5}; int args[5] = {12,23}; int args[5] = {[3]=23, [4 ...
- Python语言总结 4.2. 和字符串(str,unicode等)处理有关的函数
4.2.7. 去除控制字符:removeCtlChr Python语言总结4.2. 和字符串(str,unicode等)处理有关的函数Sidebar Prev | Up | Next4.2.7 ...
随机推荐
- 初探typescript
学习任何知识都不是一蹴而就的.typescript也是如此.今天我们来初步的了解一下typescript的安装与编译.以及基础的语法知识. 第一步:安装ts 第二步:在安装好的文件夹里面,写上ts文件 ...
- 20145215《网络对抗》Exp5 MSF基础应用
20145215<网络对抗>Exp5 MSF基础应用 基础问题回答 用自己的话解释什么是exploit,payload,encode? exploit就相当于是载具,将真正要负责攻击的代码 ...
- 多线程Java Socket编程
采用Java 5的ExecutorService来进行线程池的方式实现多线程,模拟客户端多用户向同一服务器端发送请求. 1.服务端 package localSocket; import java.i ...
- LVM基本概念及工作原理
LVM基本概念及工作原理 背景知识: 一直困惑于LVM,特地找资料查了查,终于对LVM的概念和工作原理有了深入的理解.接下来记录下.新的技术出来必定是为了改变现有的不足,所以LVM的出现是由于对现有磁 ...
- 面向对象【day07】:类的特性介绍(四)
本节内容 1.概述 2.访问属性 3.私有属性 4.总结 一.概述 在上篇博客中我们已经讲了一些关于类的知识,我们来回顾以下: 定义类(class dog(object))-> 实例化(d = ...
- 网络编程基础【day09】:实现简单地ssh(四)
本节内容 概述 简单ssh socket接收大数据的困惑 一.概述 我们用过linux的就知道什么是ssh,它是一种客户端和服务端交互返回的一个解决,输入一个命令,给我返回什么,接下来我们说一说,如何 ...
- 条理清晰的搭建SSH环境之添加所需jar包
一.首先介绍要添加框架环境: JUnit Struts2 Hibernate Spring (1)配置JUnit /**-------------------------添加JUnit-------- ...
- Java中Jdom解析XML
JDOM与DOM类似,也是一组用于解析XML的API,它本身不是一个解析器,默认的它内置了Apache的Xerces解析器:JDOM与DOM不同的是,DOM是跨语言的一套API,Java世界中有很多D ...
- 关于Java形参和实参的理解
源码地址:https://github.com/mynawang/javabasic-summary/tree/master/chapter01 1.方法的形参中,java的基本数据类型是传值调用,对 ...
- js 锚点定位【转】
锚点定义 <a name="firstAnchor">&nsbp;</a> a标签锚点使用 <a href="#firstAncho ...