Forum: Mikrocontroller und Digitale Elektronik Überlauf short int


von feldi (Gast)


Lesenswert?

Hallo
Weiß jemand wie ich berechnen kann für welches x ein Überlauf von a 
stattfinden würde.
short int sind 16 bit größen.

Ein Überlauf müsste ja stattfinden wenn a>((2^16)-1)ist.oder?
Aber wie groß ist dann i??

1
#include <iostream>
2
3
using namespace std;
4
5
int main()
6
{
7
    unsigned short int i,a=0,b=0;
8
    for(i=1;i<x;i++)
9
    {a=a+i;
10
    b=a;
11
    
12
    }
13
    return 0;
14
}

Gruß feldi
von NichtsNutz (Gast)


Lesenswert?

1+2+3+4+5...
von NichtsNutz (Gast)


Lesenswert?

Stichwort Gauss: Zähle alle Zahlen von 0 bis 100 zusammen.
von Karl H. (kbuchegg)


Lesenswert?

feldi schrieb:
> Hallo
> Weiß jemand wie ich berechnen kann für welches x ein Überlauf von a
> stattfinden würde.

Am Rechner oder mit der Hand?


Die Summe der Zahlen von 1 bis x ergibt  x*(x+1)/2  (der sog. "kleine 
Gauss")

d.h. deine Frage läuft drauf hinaus, ein x zu finden, bei dem x*(x+1)/2 
noch kleiner als 65535 ist. Oder eben

   x*(x+1)/2 = 65535

umformen, nach x auflösen und die nächst kleinere ganze Zahl nehmen
von Krapao (Gast)


Lesenswert?

Gaußsche Summenformel
http://de.wikipedia.org/wiki/Gau%C3%9Fsche_Summenformel

Dieses x geht noch:

x*(x+1)/2 = 2^16-1

x^2+x = 131070

x^2+x-131070 = 0

p-q-Formel
http://de.wikipedia.org/wiki/Quadratische_Gleichung#p-q-Formel

Ganzzahl

x = 361

361*362/2 = 65341 = 0xFF3D
362*363/2 = 65703 = 0x100A7
von Johann L. (gjlayde) Benutzerseite


Lesenswert?

Krapao schrieb:

> Ganzzahl
>
> x = 361
>
> 361*362/2 = 65341 = 0xFF3D
> 362*363/2 = 65703 = 0x100A7

Nö, x = 362 da nur über Zahlen kleiner als x summiert wird.
von Daniel H. (Firma: keine) (commander)


Lesenswert?

Also gemäß der Fragestellung

feldi schrieb:
> Weiß jemand wie ich berechnen kann für welches x ein Überlauf von a
> stattfinden würde.

feldi schrieb:
> Aber wie groß ist dann i??

gilt dann ja eigentlich:

Überlauf für x >= 363 wobei i dann 362 ist ;)
von Krapao (Gast)


Lesenswert?

Zitiere bitte korrekt. Ich schieb:

>> Dieses x geht noch:
>> ...
>> x = 361
von Achim M. (minifloat)


Lesenswert?

feldi schrieb:
> #include <iostream> [undsoweiter]
Und wo wird x deklariert?
mfg mf
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.