2014-05-09 18 views
0

我是C++编码的初学者,一般编码。当m是与线性反馈移位寄存器的输出相等的十进制数时,我已成功编写了一个代码来计算RSA算法输出C.我把代码放在一个类中,以便我可以多次使用它。编译时,我收到如下错误通知:“'keyReg'没有指定类型 keyReg.push_back(inpSeq [0]);”当这个代码在主类中时,它在编译时不会产生这样的错误。下面是完整的代码:我是否必须将非标准库包含到C++中的类定义中?

#include <iostream> 
#include <algorithm> 
#include <vector> 
#include <math.h> 
#include <boost/dynamic_bitset.hpp> 

using namespace std; 

class lfsr { 
int y, xx, polyLoc, n, end, f, e, m, c, l, g; 
boost::dynamic_bitset<> inpSeq(5); 
boost::dynamic_bitset<> operSeq(5); 
boost::dynamic_bitset<> bit(5); 
vector <int> xorArray; 
vector <int> keyReg; 
polyLoc = 320; 
while(polyLoc>0) 
{ 
    xorArray.push_back(polyLoc%10); 
    polyLoc/=10; 
} 
sort(xorArray.rbegin(), xorArray.rend()); 
operSeq = inpSeq; 
keyReg.push_back(inpSeq[0]); 
    int x = xorArray[0]; 
    do { 
    for (unsigned int r = 1; r < xorArray.size(); r++) 
    { 
    bit[seq_end] = operSeq[x]; 
    y = xorArray[r]; 
    bit[seq_end] = bit[seq_end]^operSeq[y]; 
    } 
    operSeq >>= 1; 
    operSeq[seq_end] = bit[seq_end]; 
    keyReg.push_back(operSeq[0]); 
    turnCount ++; 
} 
while ((operSeq != inpSeq) && (turnCount < 1024)); 
for (unsigned int i = 0; i < keyReg.size(); i++) 
{ 
    if (keyReg[i]==1) 
    { 
    m = m + int(pow(2,i)); 
    } 
n = p*q; 
f = (p-1)*(q-1); 
for (int k = 0; end < 1; k++) 
{ 
    if ((1+k*f)%d == 0) 
    { 
    end = 2; 
    e = (1+(k*f))/d; 
    } 
    } 
g = int(pow(m,e)); 
c = g%n; 
public: 
rsa (int, int, int, boost::dynamic_bitset); 
int key() { return (c); } 
}; 
lfsr::lfsr() //Constructor 
{ 
    y = 0; 
    turnCount = 0; 
    xx = 0; 
    polyLoc = 0; 
    n = 0; 
    end = 0; 
    f = 0; 
    e = 0; 
    m = 0; 
    c = 0; 
    l = 0, g = 0; 
}; 
lfsr::rsa (int x, int y, int z, boost::dynamic_bitset <5> initSeq) 
{ 
    p = x; 
    q = y; 
    d = z; 
    inpSeq = initSeq; 
} 
int main() 
{ 
lfsr public_key, private_key; 
public_key.rsa (29, 41, 74, 00111); 
private_key.rsa (43, 89, 73, 01011); 
cout << "Public key is: " << public_key.key() << endl; 
cout << "Private key is: " << private_key.key() << endl; 
} 
+0

你不能只将代码放入类中。你的课程需要有功能。 – jliv902

+3

请选择一本好的C++书籍和/或教程,你的类定义根本没有意义。你不能在类体中直接使用代码,只能在成员函数中使用。 – Mat

+0

好的,谢谢,我接下来的小教程没有提到那个重要的注释。 –

回答

1

在你的类上半年,似乎有直属class范围放置报表。

您需要定义成员函数来保存该代码,然后调用该类的成员函数。

对于变量,它们是在成员函数内部还是外部声明,取决于它们是需要保留还是仅用于临时存储(用于计算)。

相关问题