Contributor: SWAG SUPPORT TEAM Type Fijo=Record {estructura de un nß de coma fija} Mantisa, Decimal:Integer End; Var Var1, {variables de ejemplo} Var2:Fijo; Const Decimal_Max=100; {2 decimales} Decimal_Stellen=2; Function Strg(NumF:Fijo):String; {convierte un nß de coma fija en una cadena} Var Decimal_Str, {cadena para formar los decimales} Mantisa_Str:String; {cadena para formar la mantisa} i:Word; Begin If NumF.Decimal < 0 Then {parte decimal sin signo} NumF.Decimal:=-NumF.Decimal; Str(NumF.Decimal:Decimal_Stellen,Decimal_Str); {generar cadena decimal} For i:=0 to Decimal_Stellen do {y sustituir blancos por 0en} If Decimal_Str[i] = ' ' Then Decimal_Str[i]:='0'; Str(NumF.Mantisa,Mantisa_Str); {generar cadena de mantisa} Strg:=Mantisa_Str+','+Decimal_Str; {componer cadena} End; Procedure Convert(RZahl:Real;Var NumF:Fijo); {convierta real RZahl en nß coma fija NumF} Begin NumF.Mantisa:=Trunc(RZahl); {determinar parte mantisa} NumF.Decimal:=Trunc(Round(Frac(RZahl)*Decimal_Max)); {determinar parte decimal y guardar como nß entero} End; Procedure Adjust(Var NumF:Fijo); {devuelve el n£mero de coma fija en formato legal} Begin If NumF.Decimal > Decimal_Max Then Begin Dec(NumF.Decimal,Decimal_Max); {si parte decimal ha rebasado positivo} Inc(NumF.Mantisa); {reponer y reducir mantisa} End; If NumF.Decimal < -Decimal_Max Then Begin Inc(NumF.Decimal,Decimal_Max); {si parte decimal ha rebasado negativo} Dec(NumF.Mantisa); {reponer y aumentar mantisa} End; End; Procedure Add(Var Summe:Fijo;NumF1,NumF2:Fijo); {Suma NumF1 y NumF2 y deposita resultado en ab} Var Resultado:Fijo; Begin Resultado.Decimal:=NumF1.Decimal+NumF2.Decimal; {sumar parte decimal} Resultado.Mantisa:=NumF1.Mantisa+NumF2.Mantisa; {sumar mantisa} Adjust(Resultado); {pasar resultado a formato correcto} Summe:=Resultado; End; Procedure Sub(Var Diferencia:Fijo;NumF1,NumF2:Fijo); {resta NumF1 de NumF2 y deposita resultado en ab} Var Resultado:Fijo; Begin Resultado.Decimal:=NumF1.Decimal-NumF2.Decimal; {restar parte decimal} Resultado.Mantisa:=NumF1.Mantisa-NumF2.Mantisa; {restar mantisa} Adjust(Resultado); {pasar resultado a formato correcto} Diferencia:=Resultado; End; Procedure Mul(Var Producto:Fijo;NumF1,NumF2:Fijo); {multiplica NumF1 y NumF y deposita el resultado en ab} Var Resultado:LongInt; Begin Resultado:=Var1.Mantisa*Decimal_Max + Var1.Decimal; {formar primer factor} Resultado:=Resultado * (Var2.Mantisa*Decimal_Max + Var2.Decimal); {formar segundo factor} Resultado:=Resultado div Decimal_Max; {compensar factor aux. Decimal_Max} Producto.Mantisa:=Resultado div Decimal_Max; {extraer mantisa y parte decimal} Producto.Decimal:=Resultado mod Decimal_Max; End; Procedure Divi(Var Cociente:Fijo;NumF1,NumF2:Fijo); {divide NumF1 entre NumF2 y deposita el resultado en ab} Var Resultado:LongInt; {resultado intermedio} Begin Resultado:=NumF1.Mantisa*Decimal_Max + NumF1.Decimal; {formar contador} Resultado:=Resultado * Decimal_Max div (NumF2.Mantisa*Decimal_Max+NumF2.Decimal); {dividir por el divisor, antes disponer de mİs decimales} Cociente.Mantisa:=Resultado div Decimal_Max; {extraer parte decimal y mantisa} Cociente.Decimal:=Resultado mod Decimal_Max; End; Begin WriteLn; Convert(-10.2,Var1); {cargar dos n£meros de demo} Convert(25.3,Var2); {cİlculos propios para demostraci¢n:} Write(Strg(Var1),'*',Strg(Var2),'= '); Mul(Var1,Var1,Var2); WriteLn(Strg(Var1)); Write(Strg(Var1),'-',Strg(Var2),'= '); Sub(Var1,Var1,Var2); WriteLn(Strg(Var1)); Write(Strg(Var1),'/',Strg(Var2),'= '); Divi(Var1,Var1,Var2); WriteLn(Strg(Var1)); Write(Strg(Var1),'+',Strg(Var2),'= '); Add(Var1,Var1,Var2); WriteLn(Strg(Var1)); End.