Profilo di TonyThinking The WayFotoBlogElenchi Strumenti Guida

Blog


22/04/2008

Eclipse 3.2 DEBUG JVMJ9TI002E Error

DEBUG->

JVMJ9TI002E Agent_OnLoad not found in library jdwp
JVMJ9VM015W Initialization error for library j9jvmti23(-3): JVMJ9VM009E J9VMDllMain failed
Could not create the Java virtual machine.

是个Ecplise的bug

https://bugs.eclipse.org/bugs/show_bug.cgi?id=176471

workarounds:

* add dt_socket.dll to system path (does not work if you use different jres
(like me, i run my desktop apps on java6.0 which is in the path, but develop
for 1.4))

* configure a jre as default instead of a jdk

* copy dt_socket.dll from jdk/jre/bin to jdk/bin
30/11/1999

TICPP-VOL2-习题代码-防御性编程

//2-1
#include "../TestSuite/Test.h"
#include <vector>
using namespace std;
class VectorTest : public TestSuite::Test{
 vector<int> v_Int;
public:
 VectorTest(){
 }
 void run()
 {
  TestFuc();
 }
 void TestFuc(){
        v_Int.push_back(5);
  test_(v_Int.front()==5);
  test_(v_Int.back() == 5);
  test_(v_Int.at(0) == 5);
  v_Int.pop_back();
  test_(v_Int.size()==0);
  try{
   v_Int.at(1);
   fail_("invalited pos in vector \n");
  }
  catch (std::out_of_range) {

   succeed_();
  }
 }
};
int _tmain(int argc, _TCHAR* argv[])
{
 VectorTest obj_Test;
 obj_Test.run();
 obj_Test.report();
 getchar();
 return 0;
}

TICPP-VOL2-习题代码-异常处理

/////////////////////////////////////////////////////////
/////  VC2005                                               ////
////  Author:Tonyhuo                                    ////
////////////////////////////////////////////////////////
//1-2
#include <exception>
#include <iostream>
using namespace std;
class EXAMPLE{
public:
 class CharException{
 const char * str_Exception;
 public:
  CharException(const char * msg = 0):str_Exception(msg){}
  const char * What(){return str_Exception;}
 };
 void  f()
 {
  throw  CharException("MY Exception");
 }
};
int _tmain(int argc, _TCHAR* argv[])
{
 try{
        EXAMPLE obj;
  obj.f();
 }
 catch(EXAMPLE::CharException& e)
 {
  cout<<e.What()<<endl;
 }
 return 0;
}
///////////////////////////////////////////////////////////////////////////////////
1-4
#include <exception>
#include <iostream>
using namespace std;
int main()
{
 try{
 }
 catch(…)
 {
  cout<<"All exception caught!"<<endl;
 }
}
///////////////////////////////////////////////////////////////////////////////////////
1-9
//compile by g++
#include <exception>
#include <iostream>
#include <string>
using namespace std;
class MyException{};
class MyException2:public runtime_error{
public:
 MyException2(const string & msg =""):runtime_error(msg){}
};
void f(int i) throw(char,int,bool,MyException)
{  
 switch(i)
    {
    case 1: throw ‘a’;
    case 2: throw 32;
    case 3: throw true;
    case 4: throw MyException();
    case 5: throw MyException2();
    }
}
void my_unexpected()
{
 throw MyException2("test");;
}
void g() throw(MyException2){
    throw 3;
}
int main()
{
 for(int j =1;j<=4;j++)
  try { f(j);}
     catch(char)
  {
   cout<<"char exception caught"<<endl;
  }
  catch(int)
  {
   cout<<"int exception caught"<<endl;
  }    
  catch(bool)
  {
   cout<<"bool exception caught"<<endl;
  }    
  catch(MyException&)
  {
   cout<<"MyException exception caught"<<endl;
  }
    set_unexpected(my_unexpected);
 try{
  g();
 }
 catch (MyException2&)
 {
            cout <<"reback from g()"<<endl;
 }
 getchar();
 getchar();
}
///////////////////////////////////////////////////////////////////////////////////////////
1-11
#include <exception>
#include <iostream>
using namespace std;
class MotorError{};
class Motor{
public:
 Motor(){throw MotorError();}
};
class Car{
Motor obj_m;
public:
 Car():obj_m(){}
};
class Garage{
public:
 Car obj_c;
 Garage() try:obj_c(){

 }
 catch(MotorError&)
 {
  cout<<"Car::MotorError"<<endl;
  throw 1;
 }
};
int main()
{
 try
 {
  Garage obj;
 }
 catch(int)
 {
  cout<<"int exception caught"<<endl;
 }
 getchar();
}

LCS算法

1.最长公共子序列的结构

解最长公共子序列问题时最容易想到的算法是穷举搜索法,即对X的每一个子序列,检查它是否也是Y的子序列,从而确定它是否为X和Y的公共子序列,并且在检查过程中选出最长的公共子序列。X的所有子序列都检查过后即可求出X和Y的最长公共子序列。X的一个子序列相应于下标序列{1, 2, …, m}的一个子序列,因此,X共有2m个不同子序列,从而穷举搜索法需要指数时间。

事实上,最长公共子序列问题也有最优子结构性质,因为我们有如下定理:

定理: LCS的最优子结构性质

设序列X=<x1, x2, …, xm>和Y=<y1, y2, …, yn>的一个最长公共子序列Z=<z1, z2, …, zk>,则:

  1. 若xm=yn,则zk=xm=yn且Zk-1是Xm-1和Yn-1的最长公共子序列;
  2. 若xm≠yn且zk≠xm ,则Z是Xm-1和Y的最长公共子序列;
  3. 若xm≠yn且zk≠yn ,则Z是X和Yn-1的最长公共子序列。
其中Xm-1=<x1, x2, …, xm-1>,Yn-1=<y1, y2, …, yn-1>,Zk-1=<z1, z2, …, zk-1>。

证明

  1. 用反证法。若zk≠xm,则<z1, z2, …, zk ,xm >是X和Y的长度为k十1的公共子序列。这与Z是X和Y的一个最长公共子序列矛盾。因此,必有zk=xm=yn。由此可知Zk-1是Xm-1和Yn-1的一个长度为k-1的公共子序列。若Xm-1和Yn-1有一个长度大于k-1的公共子序列W,则将xm加在其尾部将产生X和Y的一个长度大于k的公共子序列。此为矛盾。故Zk-1是Xm-1和Yn-1的一个最长公共子序列。
  2. 由于zk≠xm,Z是Xm-1和Y的一个公共子序列。若Xm-1和Y有一个长度大于k的公共子序列W,则W也是X和Y的一个长度大于k的公共子序列。这与Z是X和Y的一个最长公共子序列矛盾。由此即知Z是Xm-1和Y的一个最长公共子序列。
  3. 与 2.类似。
这个定理告诉我们,两个序列的最长公共子序列包含了这两个序列的前缀的最长公共子序列。因此,最长公共子序列问题具有最优子结构性质

2.子问题的递归结构


由最长公共子序列问题的最优子结构性质可知,要找出X=<x1, x2, …, xm>和Y=<y1, y2, …, yn>的最长公共子序列,可按以下方式递归地进行:当xm=yn时,找出Xm-1和Yn-1的最长公共子序列,然后在其尾部加上xm(=yn)即可得X和Y的一个最长公共子序列。当xm≠yn时,必须解两个子问题,即找出Xm-1和Y的一个最长公共子序列及X和Yn-1的一个最长公共子序列。这两个公共子序列中较长者即为X和Y的一个最长公共子序列。

由此递归结构容易看到最长公共子序列问题具有子问题重叠性质。例如,在计算X和Y的最长公共子序列时,可能要计算出X和Yn-1及Xm-1和Y的最长公共子序列。而这两个子问题都包含一个公共子问题,即计算Xm-1和Yn-1的最长公共子序列。

与矩阵连乘积最优计算次序问题类似,我们来建立子问题的最优值的递归关系。用c[i,j]记录序列Xi和Yj的最长公共子序列的长度。其中Xi=<x1, x2, …, xi>,Yj=<y1, y2, …, yj>。当i=0或j=0时,空序列是Xi和Yj的最长公共子序列,故c[i,j]=0。其他情况下,由定理可建立递归关系如下:


3.计算最优值


直接利用(2.2)式容易写出一个计算c[i,j]的递归算法,但其计算时间是随输入长度指数增长的。由于在所考虑的子问题空间中,总共只有θ(m*n)个不同的子问题,因此,用动态规划算法自底向上地计算最优值能提高算法的效率。

计算最长公共子序列长度的动态规划算法LCS_LENGTH(X,Y)以序列X=<x1, x2, …, xm>和Y=<y1, y2, …, yn>作为输入。输出两个数组c[0..m ,0..n]和b[1..m ,1..n]。其中c[i,j]存储Xi与Yj的最长公共子序列的长度,b[i,j]记录指示c[i,j]的值是由哪一个子问题的解达到的,这在构造最长公共子序列时要用到。最后,X和Y的最长公共子序列的长度记录于c[m,n]中。
Procedure LCS_LENGTH(X,Y);begin  m:=length[X];  n:=length[Y];  for i:=1 to m do c[i,j]:=0;  for j:=1 to n do c[0,j]:=0;  for i:=1 to m do    for j:=1 to n do      if x[i]=y[j] then        begin          c[i,j]:=c[i-1,j-1]+1;          b[i,j]:="↖";        end      else if c[i-1,j]≥c[i,j-1] then        begin          c[i,j]:=c[i-1,j];          b[i,j]:="↑";        end      else        begin          c[i,j]:=c[i,j-1];          b[i,j]:="←"        end;  return(c,b);end;

由于每个数组单元的计算耗费Ο(1)时间,算法LCS_LENGTH耗时Ο(mn)。

4.构造最长公共子序列


由算法LCS_LENGTH计算得到的数组b可用于快速构造序列X=<x1, x2, …, xm>和Y=<y1, y2, …, yn>的最长公共子序列。首先从b[m,n]开始,沿着其中的箭头所指的方向在数组b中搜索。当b[i,j]中遇到"↖"时,表示Xi与Yj的最长公共子序列是由Xi-1与Yj-1的最长公共子序列在尾部加上xi得到的子序列;当b[i,j]中遇到"↑"时,表示Xi与Yj的最长公共子序列和Xi-1与Yj的最长公共子序列相同;当b[i,j]中遇到"←"时,表示Xi与Yj的最长公共子序列和Xi与Yj-1的最长公共子序列相同。

下面的算法LCS(b,X,i,j)实现根据b的内容打印出Xi与Yj的最长公共子序列。通过算法的调用LCS(b,X,length[X],length[Y]),便可打印出序列X和Y的最长公共子序列。
Procedure LCS(b,X,i,j);begin  if i=0 or j=0 then return;  if b[i,j]="↖" then    begin      LCS(b,X,i-1,j-1);      print(x[i]); {打印x[i]}    end  else if b[i,j]="↑" then LCS(b,X,i-1,j)
                      else LCS(b,X,i,j-1);end; 

在算法LCS中,每一次的递归调用使i或j减1,因此算法的计算时间为O(m+n)。

例如,设所给的两个序列为X=<A,B,C,B,D,A,B>和Y=<B,D,C,A,B,A>。由算法LCS_LENGTH和LCS计算出的结果如图2所示。

j 0 1 2 3 4 5 6
i yj B D C A B A
0 xi 0 0 0 0 0 0
1 A 0 0 0 0 1 1 1
2 B 0 1 1 1 1 2 2
3 C 0 1 1 2 2 2 2
4 B 0 1 1 2 2 3 3
5 D 0 1 2 2 2 3 3
6 A 0 1 2 2 3 3 4
7 B 0 1 2 2 3 4 5

图2   算法LCS的计算结果

5.算法的改进


对于一个具体问题,按照一般的算法设计策略设计出的算法,往往在算法的时间和空间需求上还可以改进。这种改进,通常是利用具体问题的一些特殊性。

例如,在算法LCS_LENGTH和LCS中,可进一步将数组b省去。事实上,数组元素c[i,j]的值仅由c[i-1,j-1],c[i-1,j]和c[i,j-1]三个值之一确定,而数组元素b[i,j]也只是用来指示c[i,j]究竟由哪个值确定。因此,在算法LCS中,我们可以不借助于数组b而借助于数组c本身临时判断c[i,j]的值是由c[i-1,j-1],c[i-1,j]和c[i,j-1]中哪一个数值元素所确定,代价是Ο(1)时间。既然b对于算法LCS不是必要的,那么算法LCS_LENGTH便不必保存它。这一来,可节省θ(mn)的空间,而LCS_LENGTH和LCS所需要的时间分别仍然是Ο(mn)和Ο(m+n)。不过,由于数组c仍需要Ο(mn)的空间,因此这里所作的改进,只是在空间复杂性的常数因子上的改进。

另外,如果只需要计算最长公共子序列的长度,则算法的空间需求还可大大减少。事实上,在计算c[i,j]时,只用到数组c的第i行和第i-1行。因此,只要用2行的数组空间就可以计算出最长公共子序列的长度。更进一步的分析还可将空间需求减至min(m, n)。

字符串中空格去除PDBD[11.12]

/*用下划线代表空格
aa_bb__ccc
应该是碰到第一个_的时候,
就是a后面那个_的时候,
把_和b交换,
就变成aab_b__ccc,
然后我从第一个b继续找_,
 然后再交换_和下一个b,
 就变成aabb___ccc
然后继续找,
下一个非空格是c,
然后交换就变成aabbc___cc
这么做下去就把所有空格推到最后了,
这样不用整体移动字符串 , 一次只交换一个字符
 */
#include "stdafx.h"
#include "stdio.h"
#include "stdlib.h"
#include "string.h"
void reblank(char * str)
{
   if(str==NULL)
    return;
   int length  = strlen(str);
   int j;
   char temp;
   bool inblank  = false;
   for(int i=0;i<length;i++)
   {
     if(str[i]==’ ‘)
     {
           if(!inblank)
           {
            inblank = true;
               j = i ;
           }
  }
     else
   {
        if(inblank)
   {
             temp  = str[j];   
    str[j] = str[i];
    str[i] = temp; 
             inblank = false;
    i = j;
            }
   }

   } 
   str[i+1] = ”; 
}
int main(int argc, char* argv[])
{
 char p[]="he  ll o";
 reblank(p);
 printf("%s\n",p);
 return 0;
}