Mistä johtuu että pienin int on yhtä suurempi kuin -2^n
https://codescracker.com/c/c-data-types.htm
https://codescracker.com/cpp/cpp-data-types.htm
https://codescracker.com/java/java-integers.htm
Myös tuolla määritellään alueet kuten javassa
https://en.wikipedia.org/wiki/Integer_(computer_science)
esim.
Signed: From −32,768 to 32,767, from −(2^15) to 2^15 − 1
c:ssä ja c :ssa esim.
−32,767 to 32,767
pienin integer eri kuin javassa
10
1436
Vastaukset
Positiivisia ja negatiivisia lukuja on eri määrä koska myös nolla on mukana.
Esimerkiksi 16-bittinen luku jolla on 65536 eri arvoa:
32768 negatiivista lukua (-32768 .. -1)
32767 positiivista lukua (1 .. 32767)
1 nolla (0)
32768 32767 1 = 65536
Näin on myös C ja C kielissä.
Näillä sivuilla on siis väärää tietoa:
https://codescracker.com/c/c-data-types.htm
https://codescracker.com/cpp/cpp-data-types.htm- Anonyymi
Mutta kun -32768 ei kuuluu lukualueeseen, esim abs(-32768) antaa vastauseksi -32768 c-kielessä
- Anonyymi
Anonyymi kirjoitti:
Mutta kun -32768 ei kuuluu lukualueeseen, esim abs(-32768) antaa vastauseksi -32768 c-kielessä
tuolla on myös -32768 ... 32767
https://en.wikipedia.org/wiki/C_data_types - Anonyymi
Anonyymi kirjoitti:
tuolla on myös -32768 ... 32767
https://en.wikipedia.org/wiki/C_data_typesIlmeisesti voi toimia oikein -2^n (n kuvaa suurin potenssia ko. lukualueelle) arvolla, mutta se ei ole varmaa: viite a b c d ja e
Anonyymi kirjoitti:
Mutta kun -32768 ei kuuluu lukualueeseen, esim abs(-32768) antaa vastauseksi -32768 c-kielessä
-32768 kuuluu lukualueeseen mutta abs(-32768) = 32768 ei kuulu.
- Anonyymi
Anonyymi kirjoitti:
Mutta kun -32768 ei kuuluu lukualueeseen, esim abs(-32768) antaa vastauseksi -32768 c-kielessä
Tuo ei ehkä pidä paikkaansa mutta jotain ongelmaa oli :)
- Anonyymi
Tuolla on -32768
ovelasti -2147483648 merkitty -2147483647 - 1
tuo johtuu kait siitä että literaali tulkitaan ensin positiivisena ja sitten vasta vaihdetaan etumerkkiä ja 2147483648 olisi liian suuri positiivinen luku
https://docs.microsoft.com/en-us/cpp/c-language/cpp-integer-limits?view=msvc-160 Nähtävästi olin väärässä ja C standardin mukaan lukualue todella on "ainakin -32767 .. 32767".
Syy on historiallinen. Tietokoneiden alkuaikoina oli useita eri tapoja miten negatiivisia lukuja esitettiin binäärimuodossa. Joissakin prosessoreissa lukualue oli -32767 .. 32767 ja toisissa -32768 .. 32767 ja yhteensopivuuden vuoksi C standardi tukee lukualuetta "ainakin -32767 .. 32767" joka on yhteensopiva noiden molempien kanssa.
Esimerkiksi Java sen sijaan on sen verran "uusi" ohjelmointikieli että sen ei tarvinnut tukea historiallisia prosessoreja joiden lukualue oli -32767 .. 32767, vaan se pystyi ottamaan lukualueeksi tuon -32768 .. 32767 jota käytännössä kaikki uudemmat prosessorit käyttivät.
Nykyään käytännössä kaikki prosessorit käyttävät "kahden komplementti" muotoa jossa lukualue on -32768 .. 32767 myös kun käytetään C-kieltä.- Anonyymi
Mistähän sinä tuon tarinan löysit
Anonyymi kirjoitti:
Mistähän sinä tuon tarinan löysit
Useista lähteistä yhdistelin, esimerkiksi:
https://en.wikipedia.org/wiki/C_data_types#cite_note-restr-5
"The minimal ranges −(2^(n−1)−1) to 2^(n−1)−1 (e.g. [−127,127]) come from the various integer representations allowed by the standard (ones' complement, sign-magnitude, two's complement). However, most platforms use two's complement, implying a range of the form −2^(m−1) to 2^(m−1)−1 with m ≥ n for these implementations, e.g. [−128,127] (SCHAR_MIN = −128 and SCHAR_MAX = 127) for an 8-bit signed char."
https://en.wikipedia.org/wiki/Signed_number_representations#History
- negatiivisten lukujen esitystapojen historiaa
Ketjusta on poistettu 0 sääntöjenvastaista viestiä.
Luetuimmat keskustelut
Ja taas ammuttu kokkolassa
Kokkolaisilta pitäisi kerätä pois kaikki ampumaset, keittiöveitset ja kaikki mikä vähänkään paukku ja on terävä.666071- 1325415
Helena Koivu on äiti
Mitä hyötyä on Mikko Koivulla kohdella LASTENSA äitiä huonosti . Vie lapset tutuista ympyröistä pois . Lasten kodista.4513322Ovatko naiset lopettaneet sen vähäisenkin vaivannäön Tinderissa?
Meinaan vaan profiileja selatessa nykyään valtaosalla ei ole minkäänlaista kirjoitettua tekstiä siellä. Juuri ja juuri s1091707Suomi vietiin Natoon väärin perustein. Viides artikla on hölynpölyä. Yksin jäämme.
Kuka vielä uskoo, että viides artikla takaa Suomelle avun, jos Suomeen hyökätään. Liikuttavasti täällä on uskottu ja ved3731247- 311127
- 671061
Sydämeni on sinun luona
Koko ajan. Oli ympärilläni ketä oli niin sinä olet vain ajatuksissa ja tunteissa. En halua muiden kosketusta kuin sinun46946Trump ja Venäjä
Huomasitteko muuten... Käytännössä ainoat valtiot, joille Trump EI eilen asettanut typeriä tariffejaan, olivat Venäjä ja110912Jatkuva stressitila
On sinun vuoksesi kun en tiedä missä mennään mutta tunteeni tiedän ainoastaan52879