|
|
|
|
|
|
|
|
|
Article del bloc de Karen
|
|
|
M'ajudeu?
dijous 1/mar/2012 - 12:24 1130 17
No se si em podreu ajudar. M'estic guanyant un eurets fent classes de reforç de mates a un fill d'una amiga meva, ara estan tocant el tema de la precedencia dels operadors, i li han posat un exercici que ha de resoldre, és el següent:
6÷2(1+2)= ?
Depen de si fas la divisió abans que la multiplicació tens resultats diferents, 1 o 9, pel cas.
Algú sap prou de mates per a donar-me un cop de ma? no se, trobo que el problema sembla fàcil, però una mica ambiguo!!!!!
Gràcies!!!!!
( · )( · ) Karen
|
|
|
|
|
|
|
Escriu articles al teu bloc
|
|
|
|
|
Comentaris sobre aquest article |
|
|
|
vetera |
No sé si et servirà...
Thursday, March 1st 2012, 5:33 PM
Normalmente, las expresiones con operadores se evalúan de izquierda a derecha, aunque no todos, ciertos operadores que se evalúan y se asocian de derecha a izquierda. Además no todos los operadores tienen la misma prioridad, algunos se evalúan antes que otros, de hecho, existe un orden muy concreto en los operadores en la evaluación de expresiones. Esta propiedad de los operadores se conoce como precedencia o prioridad.
Veremos ahora las prioridades de todos los operadores incluidos los que aún conocemos. Considera esta tabla como una referencia, no es necesario aprenderla de memoria, en caso de duda siempre se puede consultar, incluso puede que cambie ligeramente según el compilador, y en último caso veremos sistemas para eludir la precedencia.
Operadores Asociatividad
() [] -> :: . Izquierda a derecha
Operadores unitarios: ! ~ + - ++ -- & (dirección de) * (puntero a) sizeof new delete Derecha a izquierda
.* ->* Izquierda a derecha
* (multiplicación) / % Izquierda a derecha
+ - (operadores binarios) Izquierda a derecha
<< >> Izquierda a derecha
< <= > >= Izquierda a derecha
== != Izquierda a derecha
& (bitwise AND) Izquierda a derecha
^ (bitwise XOR) Izquierda a derecha
| (bitwise OR) Izquierda a derecha
&& Izquierda a derecha
|| Izquierda a derecha
?: Derecha a izquierda
= *= /= %= += -= &= ^= |= <<= >>= Derecha a izquierda
, Izquierda a derecha
La tabla muestra las precedencias de los operadores en orden decreciente, los de mayor precedencia en la primera fila. Dentro de la misma fila, la prioridad se decide por el orden de asociatividad.
La asociatividad nos dice en que orden se aplican los operadores en expresiones complejas, por ejemplo:
int a, b, c, d, e;
b = c = d = e = 10;
El operador de asignación "=" se asocia de derecha a izquierda, es decir, primero se aplica "e = 10", después "d = e", etc. O sea, a todas las variables se les asigna el mismo valor: 10.
a = b * c + d * e;
El operador * tiene mayor precedencia que + e =, por lo tanto se aplica antes, después se aplica el operador +, y por último el =. El resultado final será asignar a "a" el valor 200.
int m[10] = {10,20,30,40,50,60,70,80,90,100}, *f;
f = &m[5];
++*f;
cout << *f << endl;
La salida de este ejemplo será, 61, los operadores unitarios tienen todos la misma precedencia, y se asocian de derecha a izquierda. Primero se aplica el *, y después el incremento al contenido de f.
f = &m[5];
*f--;
cout << *f << endl;
La salida de este ejemplo será, 50. Primero se aplica el decremento al puntero, y después el *.
a = b * (c + d) * e;
Ahora el operador de mayor peso es (), ya que los paréntesis están en el grupo de mayor precedencia. Todo lo que hay entre los paréntesis se evalúa antes que cualquier otra cosa. Primero se evalúa la suma, y después las multiplicaciones. El resultado será asignar a la variable "a" el valor 2000.
Este es el sistema para eludir las precedencias por defecto, si queremos evaluar antes una suma que un producto, debemos usar paréntesis.
Quina feinada m'has donat!
|
|
|
|
|
Escriu el teu comentari per aquest article |
|
|
|
|
Ho sentim, els usuaris no registrats no poden escriure comentaris
| Registra't |
|
|
|
|