Regnearternes hierarki

Fra testwiki
Version fra 26. jul. 2023, 04:17 af imported>Harkerstein imported>Harkerstein (Definition: fakultet -> Fakultet)
(forskel) ← Ældre version | Nuværende version (forskel) | Nyere version → (forskel)
Spring til navigation Spring til søgning

Regnearternes hierarki (også kaldet regnearternes rækkefølge[1], operatorpræcedens og operatorrangfølge[2]) er inden for matematikken (aritmetik, algebra) og datalogien,[3] regelsættet der angiver rækkefølgen[4] delberegninger skal udføres i,[5] for at evaluere et givet matematisk udtryk i infiksnotation. F.eks. har multiplikation forrang fremfor addition.

Definition

Regnearternes hierarki og paranteser, som anvendes indenfor matematik, videnskab, teknologi og mange computer programmeringssprog, er her. Den højeste præcedens er øverst:[5][6][7][8][9]

Præcedens parantes
eller
operator
Kommentar
1 ()   []   {} Paranteser - men helst ikke〈〉da de kan forveksles med mindre-end og større-end tegn.
Underforståede paranteser:
N'te rods-tegnets (xn) øverste streg kan forlænges - og i så fald skal hele udtrykket "x" under stregen, opfattes som om udtrykket har en underforstået parantes. Alternativ brug: n(x).
Brøkstregen ab kan forlænges, og udtrykkene foroven "a" og forneden "b" skal opfattes, som om udtrykkene har hver deres underforståede paranteser.
2 ! Fakultet (Andre unære operatorers operatorpræcedens (fx fortegn (+) og (-)) afhænger af konventioner)
3 ^ Potensopløftning og roduddragning. I nogle programmeringssprog anvendes to stjerner (**) for potensopløftning. N'te rod kan skrives som x1n eller x^(1n).
4 *   ×     / multiplikation og division. Divisionstegn kun på engelsk: (÷) som kan misforstås som minustegn. Norsk divisionstegn kolon (:).
5 +   - Addition og subtraktion. Bemærk: Binære operatorer; plustegn (+), minustegn (-).

Det betyder at når, i et matematisk udtryk, et underudtryk er mellem to operatorer, skal operatoren, som er højere i regnearternes hierarki - udregnes først.

Eksempler

Eksempel med addition og multiplikation

Det matematiske udtryk: 2+34

skal fortolkes som 2+(34)=14

og ikke fortolkes som (2+3)4=20

Eksempel med fakultet og multiplikation

Det matematiske udtryk: Skabelon:Nowrap

skal fortolkes som Skabelon:Nowrap

og ikke fortolkes som Skabelon:Nowrap

Specialtilfælde

Unært minustegn

Der er forskellige konventioner vedrørende den unære operator − (fx minus operator). I skreven eller udskreven matematik, bliver udtrykket −32 fortolket som Skabelon:Nowrap.[7][10]

I nogle anvendelser og programmeringssprog, fx Microsoft Excel, PlanMaker (og andre regnearksprogrammer) og programmeringssproget bc, har unære operatorer højere præcedens end binære operatorer, dvs fortegn som fx negativt fortegn har højere præcedens end potensopløftning, så i disse sprog vil −32 blive fortolket som Skabelon:Nowrap.[11] Dette gælder ikke den binære minus operator −; i fx Microsoft Excel vil formlerne =−2^2, =-(2)^2 og =0+−2^2 returnere 4, hvorimod formlerne =0−2^2 og =−(2^2) returnere −4.

Blandet division og multiplikation

i dette afsnit anvendes det engelske divisionssymbol "÷"

Der kan være flertydighed i anvendelsen af skråstreg symbolet / i udtryk såsom 1/2x.[12] Hvis man omskriver dette udtryk som Skabelon:Nowrap og så fortolker divisionssymbolet som visende den multiplikative inverse, fås:

Skabelon:Nowrap.

Med denne fortolkning Skabelon:Nowrap er det lig med Skabelon:Nowrap.[7][13] Men i en del akademisk litteratur, anvendes underforstået multiplikation, som bliver fortolket som havende højere præcedens end division, sådan at Skabelon:Nowrap er lig Skabelon:Nowrap, ikke Skabelon:Nowrap.

Fx er manuskript indsendelsesinstruktionerne for tidsskriftet Physical Review at (kun underforstået?) multiplikation har højere præcedens end division med en skråstreg,[14] og dette er også konventionen observeret i prominente fysikbøger såsom Course of Theoretical Physics af Landau og Lifshitz - og Feynman Lectures on Physics.[15] [16]

Lommeregner

Nogle lommeregnere respekterer regnearternes hierarki, andre gør ikke.[7]

Programmeringssprog

Nogle programmeringssprog anvender regnearternes hierarki, som er kompatibel med hvad der anvendes i matematik,[17] selvom andre, såsom APL, Smalltalk, Occam and Mary, ikke har operator præcedens regler (i APL er evaluering striks fra højre til venstre; i Smalltalk osv. er det striks venstre til højre).

Yderligere, fordi mange operatorer ikke er associative, er præcedensen indenfor ethvert enkelt niveau sædvanligvis defineret ved at gruppere venstre til højre så at 16/4/4 fortolkes som Skabelon:Nowrap i stedet for Skabelon:Nowrap; sådanne operatorer bliver måske fejlagtigt kaldet for "venstre associativ". Undtagelser eksisterer; fx, sprog med operatorer som korresponderer til cons operation på lister grupperer dem typisk fra højre til venstre ("højre associativ"), fx i Haskell, 1:2:3:4:[] == 1:(2:(3:(4:[]))) == [1,2,3,4].

Skaberen af programmeringssproget C har sagt at præcedens i C (programmeringssprog som låner disse regler fra C, er fx: C++, Perl og PHP), ville være mere formålstjenligt hvis bitwise operatorer flyttes op over sammenligningsoperatorer.[18] Men mange programmører er blevet tilvænt til denne præcedens. Det relative præcedens niveau af operatorer, der findes i mange C-lignende sprog, er som følger:

Præcedens parantes eller operator Kommentar
1 ()   []   ->   .   :: Funktionskald, virkefelt (scope), array/member access
2 !   ~   -   +   *   &   sizeof   typekonvertering (type cast)   ++   --   (fleste) unære operatorer, sizeof og typekonvertering (højre til venstre)
3 *   /   % MOD Multiplikation, division, modulo
4 +   - Addition og subtraktion
5 <<   >> Bitvis shift venstre og højre
6 <   <=   >   >= Sammenligning: mindre-end og større-end
7 ==   != Sammenligning: lig og ikke-lig
8 & Bitvis AND
9 ^ Bitvis exclusive OR (XOR)
10 | Bitvis inclusive (normal) OR
11 && Logisk AND
12 || Logisk OR
13 ? : Betinget udtryk (ternær)
14 =   +=   -=   *=   /=   %=   &=   |=   ^=   <<=   >>= Tildelingsoperatorer (højre til venstre)
15 , Kommaoperator

Se også

Bøger

  • Carstensen, Jens & Frandsen, Jesper (1990): Obligatorisk matematik. Forlaget Systime, Herning. Skabelon:ISBN
  • Holth, Klaus m.fl. (1987): Matematik Grundbog 1. Forlaget Trip, Vejle. Skabelon:ISBN

Referencer

Skabelon:Reflist

  1. https://www.matematikfysik.dk/mat/opgaver/grundforloeb%20-%20opgaver%20i%20regnearternes%20hierarki.pdf , backup
  2. Engelsk-dansk it-ordbog. Af Jørgen Høedt
  3. Regnearternes hierarki og problemløsning i 1. gymnasieklasse - PDF Gratis download, backup
  4. Gennemgang af regnearternes hierarki (artikel). Khan Academy, backup
  5. 5,0 5,1 gymnasiet.dk: matematik-kompedium, backup
  6. lektieforum.dk: Hvad er rækkefølgen på de forskellige regnearter?, backup
  7. 7,0 7,1 7,2 7,3 Skabelon:Cite book
  8. Skabelon:Cite web
  9. Skabelon:Cite web
  10. Skabelon:Cite book
  11. Skabelon:Cite web
  12. Skabelon:Cite book
  13. Skabelon:Cite web
  14. Skabelon:Cite web
  15. For example, the third edition of Mechanics by Landau and Lifshitz contains expressions such as hPz/2Skabelon:Pi (p. 22), and the first volume of the Feynman Lectures contains expressions such as 1/2Skabelon:Sqrt (p. 6–7). In both books, these expressions are written with the convention that the solidus is evaluated last. This also implies that an expression like 8/2(4) has solution 1 as the omission of the multiplication sign (x * or .) implies that the solidus is evaluated last even if positioned more to the left.
  16. "Of" is equivalent to division or multiplication, and commonly used especially at primary school level, as in "Half of fifty".
  17. Skabelon:Cite web
  18. Skabelon:Cite book