Ich habe folgende sortierten Daten:Algorithmus für die Zählung Sortiert Strings (Homebrew "uniq -c")
AAA
AAA
TCG
TTT
TTT
TTT
ich die Vorkommen jedes String zählen möchten:
AAA 2
TCG 1
TTT 3
Ich weiß, ich kann das mit uniq -c
tun, aber hier muss ich zusätzliche Verarbeitung für den gesamten C++ - Code, den ich habe. (Nach 'pgras' Vorschlag modifiziert)
ich mit diesem Konstrukt stecke:
#include <iostream>
#include <vector>
#include <fstream>
#include <sstream>
using namespace std;
int main (int arg_count, char *arg_vec[]) {
if (arg_count !=2) {
cerr << "expected one argument" << endl;
return EXIT_FAILURE;
}
string line;
ifstream myfile (arg_vec[1]);
if (myfile.is_open())
{
int count;
string lastTag = "";
while (getline(myfile,line))
{
stringstream ss(line);
string Tag;
ss >> Tag; // read first column
//cout << Tag << endl;
if (Tag != lastTag) {
lastTag = Tag;
count = 0;
}
else {
count++;
}
cout << lastTag << " " << count << endl;
}
cout << lastTag << " " << count << endl;
myfile.close();
}
else {cout << "Unable to open file";}
return 0;
}
Er druckt dieses falsche Ergebnis:
AAA 0
AAA 1
TCT 0
TTT 0
TTT 1
TTT 2
TTT 2
Dies wird nicht kompilieren. Count ist zum Beispiel nicht definiert. Ich weiß auch nicht genau, was Ihre "Extra-Verarbeitung" ist. Kannst du genauer sein? –
@John: Ich muss dieses uniq-Tag verarbeiten, indem ich einen Wert gebe, und diese Tags zusammen mit der Zählung erneut ausgeben, z. AAA 2 -40 40 40 – neversaint
Sorry, mir ist noch nicht klar. Was sind die "-40 40 40" in Ihrem letzten Beispiel hier? –