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.
Paranteser - men helst ikke〈〉da de kan forveksles med mindre-end og større-end tegn. Underforståede paranteser: N'te rods-tegnets () ø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: . Brøkstregen kan forlænges, og udtrykkene foroven "a" og forneden "b" skal opfattes, som om udtrykkene har hver deres underforståede paranteser.
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.
Der er forskellige konventioner vedrørende den unære operator − (fx minus operator). I skreven eller udskreven matematik, bliver udtrykket −32 fortolket som 0 − (32) = − 9.[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 (−3)2 = 9.[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 1 ÷ 2x og så fortolker divisionssymbolet som visende den multiplikative inverse, fås:
1 ÷ 2 × x = 1 × 1/2 × x = 1/2 × x.
Med denne fortolkning 1 ÷ 2x er det lig med (1 ÷ 2)x.[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 1 ÷ 2x er lig 1 ÷ (2x), ikke (1 ÷ 2)x.
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 (16/4)/4 = 1 i stedet for 16/(4/4) = 16; 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:
^ abcdBronstein, Ilja Nikolaevič; Semendjajew, Konstantin Adolfovič (1987) [1945]. "2.4.1.1. Definition arithmetischer Ausdrücke" [Definition of arithmetic expressions]. Skrevet i Leipzig, Germany. I Grosche, Günter; Ziegler, Viktor; Ziegler, Dorothea (red.). Taschenbuch der Mathematik [Pocketbook of mathematics] (tysk). Vol. 1. Oversat af Ziegler, Viktor. Weiß, Jürgen (23 udgave). Thun, Switzerland / Frankfurt am Main, Germany: Verlag Harri Deutsch (and B. G. Teubner Verlagsgesellschaft, Leipzig). s. 115-120, 802. ISBN3-87144-492-8. Regel 7: Ist F(A) Teilzeichenreihe eines arithmetischen Ausdrucks oder einer seiner Abkürzungen und F eine Funktionenkonstante und A eine Zahlenvariable oder Zahlenkonstante, so darf F A dafür geschrieben werden. [Darüber hinaus ist noch die Abkürzung Fn(A) für (F(A))n üblich. Dabei kann F sowohl Funktionenkonstante als auch Funktionenvariable sein.]
^Weisstein, Eric W. "Precedence". mathworld.wolfram.com (engelsk). Hentet 2020-08-22.
^For example, the third edition of Mechanics by Landau and Lifshitz contains expressions such as hPz/2π (p. 22), and the first volume of the Feynman Lectures contains expressions such as 1/2√N(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.
^"Of" is equivalent to division or multiplication, and commonly used especially at primary school level, as in "Half of fifty".