Bjarne Stroustrup Einführung in die Prog... Problem
-
Gar nicht ,stimmmt, danke.
-
Ich bekomme das einfach nicht hin.
Es sollen nur die Primzahlen ausgegeben werden.Das habe ich im int main stehen
int prime_temp(0), max(0), step(0), temp(0), temp2; bool ok=true; vector<int>prime(prime_temp); prime.push_back(2); prime.push_back(3); cout << "Bitte geben Sie das Tabellenende an (z.B. 100). "; del(); cin >> max; cout << "\n\n----------------- Primezahlen-Tabelle ----------------------\n\n"; for(step=4; step<=max; ++step) // zahl hochzählen bis max erreicht ist. { temp=prime.size(); ok=true; if(ok==true) { for(int i=0; i<prime.size();) { if(step%prime[prime_temp]!=0) { if(i+1==prime.size()) { prime.push_back(step); cout << step << " ist eine Primezahl " << endl; /*for(int a=0; a<prime.size(); ++a){ cout << "prime[" << a << "]==" << prime[a] << '\n'; }*/ } else { i++; } } else if(step%prime[prime_temp]==0) { temp2=prime.size(); i=temp2; } } } else { ; } }
-
Habs gelöst bekommen.
bool ok; int max, teiler, zahl, temp; vector<int>prime; cout << "Bitte geben Sie das Tabellenende an (z.B. 100): "; del(); cin >> max; cout << "\n\n----------------- Primezahlen-Tabelle ----------------------\n\n"; for(zahl=2; zahl<=max; zahl++) { ok=true; for(temp=0; temp<prime.size(); temp++) { if(zahl%prime[temp]==0) { ok=false; } } if(ok==true) { prime.push_back(zahl); cout << "\n V.Platz: " << temp << "\t\t Wert: " << prime[temp]; } }
-
Folgende Verbesserungen:
- schreibe für den Test, ob eine Zahl prim ist, eine Funktion
- Bei der Schleife, die einen Teiler der Zahl finden soll, reicht es bis Wurzel(Zahl) zu iterieren#include <iostream> #include <cmath> bool isPrime(int n) { if (n <= 0) return false; for(int i=2; i<std::sqrt(n); i++) if(n%i==0) return false; return true; } int main() { int o = 0; while(o<1) { std::cout << "Bitte Obergrenze angeben:" << std::endl; std::cin >> o; } for(int i=1; i < o; i++) std::cout << "Die Zahl " << i << isPrime(i) ? " ist eine Primzahl." : " ist keine Primzahl." << std::endl; return 0; }
*Edit: Das hier nur die Primzahlen bis zur Obergrenze ausgegeben werden, ist so gewollt und hat gar nichts damit zu tun, dass ich die Aufgabenstellung nicht gelesen haben *hust*
-
Ich möchte vergleichen, ob im 0 dann im 1 , 2 usw der gleiche String drin steht.
Was hier dran falsch?for(int q=0; q<names.size(); q++) { if(names[q]==names.back()) { age.pop_back(); names.pop_back(); ok=false; } else { ; } }
-
ohne Definition von Names kann man da nur raten
-
#include <iostream> #include <string> void del() { cin.sync(); cin.clear(); } int main() { vector<string>names; string temp_n; vector<int>age; int temp_a; bool ok=true; while(ok==true) { cout << "Geben Sie einen Namen und das Atler an." << endl; del(); cin >> temp_n; if(temp_n!="noname" && temp_n!="exit") { names.push_back(temp_n); del(); cin >> temp_a; age.push_back(temp_a); if(temp_a>120 ||temp_a<1||cin.fail()) { age.pop_back(); names.pop_back(); ok=false; cout << "\nFalsche Eingabe fail cin . " << endl; } else { ; } for(int q=0; q<names.size(); q++) { if(names[q]==names.back()) { age.pop_back(); names.pop_back(); ok=false; } else { ; } } } else if(ok=false) { ok=false; } } for(int i=0; i<names.size(); i++) { cout << "\n\nV.Platz (Names): " << i << "\t\t Name: " << names[i] ; cout << "\nV.Platz (Age): " << i << "\t\t Alter: " << age[i] ; } cout << "\n\n"; system("pause"); return 0; }
Fehler gefunden
Ab Zeile 43 hat er den letzten Vektorplatz mit dem letzten Platz verglichen.Dupletfinder=names.size(); Dupletfinder-=1; for(int q=0; q<Dupletfinder; q+=1) { if(names[q]==names.back()) {
-
Bin nun bei Kapitel 6 dort soll ich eine Taschenrecher.cpp kompiliern und die Fehler beseitigen.
Ich komme einfach nicht dahinter wo diese Fehler sind.
Vielleicht könnt ihr mir helfen.
Bei Zeile 69, müsste doch "==true" ergänzt werden, aber in der ganzen Funktion beschwert er sich full und buffer nicht zu kennen.// // Dieser Beispielcode stammt aus dem Aufgabenteil von Kapitel 6 des Buches // "Einführung in die Programmierung mit C++" von Bjarne Stroustrup // /* Diese Datei heißt calculator02buggy.cpp Ich habe 5 Fehler eingefügt, die korrigiert werden müssen, damit sich das Programm kompilieren lässt Ich habe 3 logische Fehler eingefügt, die zu falschen Ergebnissen führen sollten Versuchen Sie zunächst, die Fehler ohne Zuhilfenahme des Buches zu finden. Wenn dies zu mühsam wird, vergleichen Sie den Code mit dem Code im Buch (oder der Beispielsammlung) Fröhliche Jagd! */ #include "std_lib_facilities.h" //------------------------------------------------------------------------------ lass Token { public: char kind; // welche Kategorie von Token double value; // für Zahlen: ein Wert Token(char ch) // erstelle ein Token aus einem char :kind(ch), value(0) { } Token(char ch, double val) // erstelle ein Token aus einem char und einem double :kind(ch), value(val) { } }; //------------------------------------------------------------------------------ class Token_stream { public: Token_stream(); // erstelle einen Token_stream, der aus cin liest Token get(); // lies ein Token ein (get() ist anderswo definiert) void putback(Token t); // lege ein Token zurück private: bool full; // befindet sich ein Token im Puffer? Token buffer; // hier legen wir ein Token ab, das mit putback() // zurückgestellt wurde }; //------------------------------------------------------------------------------ // Der Konstruktor setzt full auf false, um anzuzeigen, dass der Puffer leer ist: Token_stream::Token_stream() :full(false), buffer(0) // kein Token im Puffer { } //------------------------------------------------------------------------------ // Die Memberfunktion putback() stellt ihr Argument zurück in den Puffer von Token_stream: void Token_stream::putback(Token t) { if (full) error("putback(): Zurueckstellen nicht moeglich, Puffer voll"); buffer = t; // kopiere t in den Puffer full = true; // Puffer ist jetzt voll } //------------------------------------------------------------------------------ Token get() { if (full) { // gibt es bereits ein fertiges Token? // Token aus dem Puffer entfernen full=false; return buffer; } char ch; cin >> ch; // beachten Sie, dass >> Whitespace-Zeichen wie // Leerzeichen, Zeilenumbruch, Tabulatorzeichen, etc. überspringt switch (ch) { case ';': // für "Ausgeben" case 'q': // für "Verlassen" case '(': case ')': case '+': case '-': case '*': case '/': return Token(ch); // jedes Zeichen repräsentiert sich selbst case '.': case '0': case '1': case '2': case '3': case '4': case '5': case '6': case '7': case '9': { cin.putback(ch); // lege die Ziffer zurück in den Eingabestream double val; cin >> val; // lies eine Gleitkommazahl return Token('8',val); // '8' repräsentiert "eine Zahl" } default: error("Ungueltiges Token"); } } //------------------------------------------------------------------------------ Token_stream ts; // stellt get() und putback() zur Verfügung //------------------------------------------------------------------------------ double expression(); // Deklaration, damit primary() expression() aufrufen kann //------------------------------------------------------------------------------ // behandelt Zahlen und Klammern double primary() { Token t = ts.get(); switch (t.kind) { case '(': // behandle'(' Ausdruck ')' { double d = expression(); t = ts.get(); if (t.kind != ')') error("')' expected); return d; } case '8': // wir verwenden '8' zur Repräsentation einer Zahl return t.value; // liefere den Wert der Zahl zurück default: error("Faktor erwartet"); } } //------------------------------------------------------------------------------ // behandelt *, / und % double term() { double left = primary(); Token t = ts.get(); // lies das nächste Token aus dem Token-Stream ein while(true) { switch (t.kind) { case '*': left *= primary(); t = ts.get(); case '/': { double d = primary(); if (d == 0) error("Division durch null"); left /= d; t = ts.get(); break; } default: ts.putback(t); // stelle t wieder zurück in den Token-Stream return left; } } } //------------------------------------------------------------------------------ // behandelt + und – double expression() { double left = term(; // liest einen Token ein und wertet ihn aus Token t = ts.get(); // lies das nächste Token aus dem Token-Stream ein while(true) { switch(t.kind) { case '+': left += term(); // werte Term aus und addiere t = ts.get(); break; case '-': left += term(); // werte Term aus und subtrahiere t = ts.get(); break; default: ts.putback(t); // stelle t wieder zurück in den Token-Stream return left; // keine weiteren + oder –; Antwort zurückliefern } } } //------------------------------------------------------------------------------ int main() try { while (cin) { Token t = ts.get(); if (t.kind == 'q') break; // 'q' für "verlassen" if (t.kind == ';') // ';' für "jetzt ausgeben" cout << "=" << val << '\n'; else ts.putback(t); val = expression(); } keep_window_open(); } catch (exception& e) { cerr << "Fehler: " << e.what() << '\n'; keep_window_open(); return 1; } catch (...) { cerr << "Hoppla: unbekannte Ausnahme!\n"; keep_window_open(); return 2; } //------------------------------------------------------------------------------
-
Zeile 67 müsste so aussehen:
Token Token_stream::get()
Die restlichen Fehler kannst du dann noch selber suchen.
Das "==true" ist übrigens nicht notwendig.
-
Zeto schrieb:
Bei Zeile 69, müsste doch "==true" ergänzt werden,
Nein, das wäre überflüssig. Der Ausdruck beim if wird immer auf wahrheit überprüft, das braucht man nicht mit true zu vergleichen. Kann man machen, gibgt aber auch nur wieder einen booleschen Ausdruck, der entweder true oder false ist. Man kanns dann natürlich immer weiter treiben...
if ((true == (full == true)) == true)
aber in der ganzen Funktion beschwert er sich full und buffer nicht zu kennen.
Weil du get als freie Funktion definierst, die nichts mit Token_stream zu tun hat. Das ist bestimmt nicht beabsichtigt...
-
Zeile 190 wird val nicht gefunden.
Kann es sein das man in Global/lokal in main anlegen muss?
-
Zu deiner Frage: am besten in der main-Funktion anlegen, jep.
Ein Tipp: Schau dir danach mal Zeile 117 an.
-
So habe ich die 117 gelöst
if (t.kind != ')') error("')' expected");
-
-
Kennt jemand ne Seite auf der man Token erklärt bekommt, finde das die im Buch zu schnell das Thema durchziehen?
-
Zeto schrieb:
Kennt jemand ne Seite auf der man Token erklärt bekommt, finde das die im Buch zu schnell das Thema durchziehen?
-
Ich meinte eher, wie man mit Token arbeiten kann.
-
Zeto schrieb:
Kennt jemand ne Seite auf der man Token erklärt bekommt, finde das die im Buch zu schnell das Thema durchziehen?
Zeto schrieb:
Ich meinte eher, wie man mit Token arbeiten kann.
Was hast du bei dem Thema nicht verstanden? Das Thema selbst gibt nicht viel her. Ein Token ist eine Informationseinheit und hat eine bestimmte Bedeutung. Es ist aus einem oder mehreren Zeichen aufgebaut, die Bedeutung hängt meist von den Zeichen und ggf. vom Kontext ab.
So ähnlich wie Wörter und Satzzeichen in einem Satz
-
IN Zeile 20 gibt er mir einen Linker-Error aus.
class Token { public: char kind; double value; Token(char ch) :kind(ch), value(0){} Token(char ch, double val) :kind(ch), value(val){} }; Token get_token(); vector<Token>tok; int main() { while (cin) { Token t = get_token(); tok.push_back(t); } cout << '\n'; system("pause"); return 0; }
-
Zeto schrieb:
IN Zeile 20 gibt er mir einen Linker-Error aus.
Wäre auch schön, wenn du den dazu schreibst, und die C++ Tags für Code verwendest.
Ich tippe mal darauf das du die Funktion "Token get_token()" nirgends definiert hast. Zudem solltest du dir globale Variablen gleich abgewöhnen ("vector<Token>tok").