1

sum+ にあるビットの 1 の補数を取得し、補数されたビットを finalsum に保存したいと考えています。どうやってするか。私は bitvec と uint32_t タイプのものを使用するのが少し苦手です。だから私はここで混乱しています。助けてください。

#include <iostream>
#include <string>
#include <bitset>
using namespace std;
#include <vector>
#include <stdint.h>

int main() {
int i;
string j;

std::string message = "hello "; // Some string.
std::vector<uint16_t> bitvec;
unsigned char* cp = message.c_str()+1;
while (*cp) {
   uint16_t bits = *(cp-1)>>8 + *(cp);
   bitvec.push_back(bits);
}

uint32_t sum=0;
uint16_t overflow=0;

for(auto j = bitvec.begin(); j != bitvec.end(); ++j) { 
sum += *j;
std::uint16_t; overflow = sum>>16;  //capture the overflow bit, move it back to lsb
sum &= (1<<16)-1;    //clear the overflow
sum += overflow;     //add it back as lsb
}

uint32_t finalsum=0;
for (k=0; k<=sum.length(); k++)
{finalsum = !(sum[k])]
}

cout << finalsum ;
return 0;

}
4

1 に答える 1

3

TCP の 1 の補数チェックサムのようなものを実装しようとしているようです。

// Compute the sum.  Let overflows accumulate in upper 16 bits.
for(auto j = bitvec.begin(); j != bitvec.end(); ++j) 
    sum += *j;

// Now fold the overflows into the lower 16 bits.  This requires two folds, as the
// first fold may generate another carry.  This can't happen more than once though.
sum = (sum & 0xFFFF) + (sum >> 16);
sum = (sum & 0xFFFF) + (sum >> 16);

// Return the 1s complement sum in finalsum
finalsum = sum;

これでうまくいくはずです。

cp += 2別のメモとして、このループのどこかに必要だと思います:

while (*cp) {
    uint16_t bits = *(cp-1)>>8 + *(cp);
    bitvec.push_back(bits);
    cp += 2;  // advance to next pair of characters
}

入力文字列が偶数文字でない場合、そのループも失敗するため、より堅牢に書き直すことを検討してください...

于 2013-11-09T09:47:02.400 に答える