Akaria Geschrieben 25. April 2009 Teilen Geschrieben 25. April 2009 Hallo, ich soll ein Programm schreiben (Microsoft Visual C++) und brauch um da weiter zu kommen den Befehl, wo die stellen eines int's gezählt werden (bsp: 12345678 = 8 Stellen) Hat einer von euch eine Ahnung wie der Befehl heißt, ich hab schon im Netz gesucht, aber so gerade nichts gefunden. mfg Akaria Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Der Kleine Geschrieben 25. April 2009 Teilen Geschrieben 25. April 2009 mathematisch: int(log(x,10)) Ganzzahlanteil des dekadischen Logarithmusses (also zur Basis 10). Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 Eine fertige Funktion gibt's nicht, du musst das ausprogrammieren. Weitere Vorschläge: Pragmatisch: Mitzählen, wie oft du durch 10 teilen musst, bis 0 herauskommt. Simpel, aber verschwenderisch: In einen String umwandeln und dessen Länge ermitteln. Performant: Binäre Suche in einer Lookup-Tabelle. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Perfiliev Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 int DigitalCount(int x) { int j=0; while(x>0) { x=x/10; j++; } return j; } Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Der Kleine Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 int j=log10(x); Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Klotzkopp Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 Beide Varianten funktionieren nur für x > 0. So könnte man es auch machen: int digit_count( int x ) { static const int table[] = { 10, 100, 1000, 10000, 100000, 1000000, 10000000, 100000000, 1000000000 }; return std::upper_bound( table, table + 9, abs(x) ) - table + 1; } [/code] Das klappt so allerdings nur, wenn int höchstens 32 Bit hat. Man könnte die Tabelle aber auf 64 Bit erweitern. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Der Kleine Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 Beide Varianten funktionieren nur für x > 0 dann halt aus dem x noch ein abs(x) gemacht und x=0 ausgeschlossen. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Perfiliev Geschrieben 26. April 2009 Teilen Geschrieben 26. April 2009 dann halt aus dem x noch ein abs(x) gemacht Genau Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Akaria Geschrieben 26. April 2009 Autor Teilen Geschrieben 26. April 2009 Danke schön, das mit dem durch 10 teilen probier ich die tage mal aus. das mit dem logarithmus auch mal (bin mal gespannt ob das funktioniert) Mfg Akaria Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.