将C ++代码翻译成Python的正确方法

时间:2016-05-04 15:35:44

标签: python c++

我有一个C ++代码执行以下操作:

U[0]=rate[0];
map<int,double> Q[N+1];           
map<int,double> r[N+1];           
map<int,double> d[N+1];           
r[0][0]=rate[0];
d[0][0]=1/(1+r[0][0]*dt);
Q[0][0]=1.0;
for(int i=1;i<=N;i++)
{
    for(int j=-i;j<=i;j=j+2)
    {      
        if(j==i)
            {Q[i][i]= 0.5*Q[i-1][i-1]*d[i-1][i-1];}
        if(j==-i)
            {Q[i][-i]=0.5*Q[i-1][-i+1]*d[i-1][-i+1];}

        Q[i][j]=0.5*(Q[i-1][j-1]*d[i-1][j-1]+Q[i-1][j+1]*d[i-1][j+1]);
    }
}

我需要为此编写等效的Python版本,因为我对C ++不太满意。我做了以下事情:

Q, U, r, d = [], [], [], []
Q.append([])
Q[0].append(1)
U.append(rate[1])
r.append([])
r[0].append(rate[1])
d.append([])
d[0].append(1/(1+r[0][0]*dt))
for i in range(0, N):
    for j in range(-i, i, 2):
        if j == i:
            Q[i].append(0.5*Q[i-1][i-1]*d[i-1][i-1])
        elif j == -i:
            Q[i].insert(-i, (0.5*Q[i-1][-i+1]*d[i-1][-i+1]))
        Q[i].insert(j, 0.5*(Q[i-1][j-1]*d[i-1][j-1]+Q[i-1][j+1]*d[i-1][j+1]))

但是,我在此行中收到index out of range错误:

Q[i].insert(-i, (0.5*Q[i-1][-i+1]*d[i-1][-i+1]))

如何正确地将C ++代码转换为它的python等价物?

1 个答案:

答案 0 :(得分:2)

您会收到索引错误,因为您的数组未预先​​填充,就像它们在C ++中一样。

尝试定义它们:

from collections import defaultdict
...

#map<int,double> Q[N+1];
Q = [defaultdict(float) for _ in range(N+1)]

#map<int,double> r[N+1];
r = [defaultdict(float) for _ in range(N+1)]

#map<int,double> d[N+1];
d = [defaultdict(float) for _ in range(N+1)]
  

如何正确地将C ++代码转换为python等价物?

如果是我,而且我不理解我开始使用的代码,那么我会逐行进行逐行表达式转换。

我还要求使用C ++代码正确运行的测试用例并对其进行调整以确认Python代码。

这是我的逐行,UNTESTED翻译:

from collections import defaultdict


#NameError: name 'N' is not defined
N = 12

#NameError: name 'rate' is not defined
rate = [.03]

#NameError: name 'dt' is not defined
dt = 1.0/12


#U[0]=rate[0];
#  unused

#map<int,double> Q[N+1];
Q = [defaultdict(float) for _ in range(N+1)]

#map<int,double> r[N+1];
r = [defaultdict(float) for _ in range(N+1)]

#map<int,double> d[N+1];
d = [defaultdict(float) for _ in range(N+1)]

#r[0][0]=rate[0];
r[0][0] = rate[0]

#d[0][0]=1/(1+r[0][0]*dt);
d[0][0] = 1 / (1 + r[0][0] * dt)

#Q[0][0]=1.0;
Q[0][0] = 1.0

#for(int i=1;i<=N;i++)
#{
for i in range(1, N+1, 1):

#    for(int j=-i;j<=i;j=j+2)
#    {
    for j in range(-i, i+1, 2):

#        if(j==i)
#            {Q[i][i]= 0.5*Q[i-1][i-1]*d[i-1][i-1];}
        if j == i:
            Q[i][i] = 0.5 * Q[i-1][i-1] * d[i-1][i-1]

#        if(j==-i)
#            {Q[i][-i]=0.5*Q[i-1][-i+1]*d[i-1][-i+1];}

        if j == -i:
            Q[i][-i] = 0.5 * Q[i-1][-i+1] * d[i-1][-i+1]

#        Q[i][j]=0.5*(Q[i-1][j-1]*d[i-1][j-1]+Q[i-1][j+1]*d[i-1][j+1]);
        Q[i][j] = 0.5 * (Q[i-1][j-1] * d[i-1][j-1] + Q[i-1][j+1] * d[i-1][j+1])
#    }
#}