Delphi - como puedo hacerle para sacar el valor en fraccion

 
Vista:
sin imagen de perfil
Val: 3
Ha mantenido su posición en Delphi (en relación al último mes)
Gráfica de Delphi

como puedo hacerle para sacar el valor en fraccion

Publicado por luis (3 intervenciones) el 16/07/2019 17:59:49
hola quiero saber como puedo hacerle para sacar el valor en fraccion es de una formula general solo me falta sacar eso ayuda !!!

el programa es en masm32 ensamblador


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
.486
.model flat,stdcall
option casemap :none
 
include \masm32\include\windows.inc
include \masm32\macros\macros.asm
include \masm32\include\masm32rt.inc
includelib \masm32\lib\masm32.lib
includelib \masm32\lib\kernel32.lib
includelib \masm32\lib\gdi32.lib
include \masm32\include\user32.inc
 
equisuno MACRO aa,bb,cc
;x=(-b+-raiz(b2-4ac))/2a
;A=b*b
mov eax,bb
mul eax
mov ebx,eax
 
;B=4*a*c
mov eax,4
mul aa
mul cc
 
;C=A-B
sub ebx,eax
;mov eax,ebx
 
;D=RAIZ(C)
xor ecx,ecx
 
calculo:
mul ecx
mov eax,ecx
cmp eax,ebx
ja mayor
jb menor
je igual
 
menor:
inc ecx
mov eax,ecx
mul ecx
cmp eax,ebx
ja mayor
je igual
jb menor
 
mayor:
dec ecx
jmp igual
 
igual:
mov eax,ecx
 
;x1=(-b+D)/2a
;E=-b
mov ebx,bb
not ebx
inc ebx
 
;F=E+D
add ebx,eax
 
;G=2a
mov eax,aa
mov ecx,2
mul ecx
 
;H=F/G
Invoke IntDiv, ebx,eax
 
print str$(eax)
ENDM
 
equisdos MACRO aa,bb,cc
;x=(-b+-raiz(b2-4ac))/2a
;A=b*b
mov eax,bb
mul eax
mov ebx,eax
 
;B=4*a*c
mov eax,4
mul aa
mul cc
 
;C=A-B
sub ebx,eax
;mov eax,ebx
 
;D=RAIZ(C)
xor ecx,ecx
 
calculoa:
mul ecx
mov eax,ecx
cmp eax,ebx
ja mayora
jb menora
je iguala
 
menora:
inc ecx
mov eax,ecx
mul ecx
cmp eax,ebx
ja mayora
je iguala
jb menora
 
mayora:
dec ecx
jmp iguala
 
iguala:
mov eax,ecx
 
;x2=(-b+D)/2a
;E=-b
mov ebx,bb
not ebx
inc ebx
 
;F=E-D
sub ebx,eax
 
;G=2a
mov eax,aa
mov ecx,2
mul ecx
 
;H=F/G
Invoke IntDiv, ebx,eax
 
print str$(eax)
ENDM
 
.code
start:
call Main
exit
 
Main proc
LOCAL a1 ;DWORD
LOCAL b1 ;DWORD
LOCAL c1 ;DWORD
print chr$(13,10)
print chr$("FORMULA GENERAL LA ULTIMA Y NOS VAMOS ")
print chr$(13,10)
print chr$(13,10)
print chr$(13,10)
print chr$("Identifica A, B y C ")
print chr$(13,10)
print chr$(13,10)
print chr$(13,10)
mov a1, sval(input("A= "))
print chr$(13,10)
mov b1,  sval(input("B= "))
print chr$(13,10)
mov c1,  sval(input("C= "))
print chr$(13,10)
print chr$(13,10)
print chr$(13,10,"x1= ")
equisuno a1,b1,c1
print chr$(13,10)
print chr$(13,10,"x2= ")
equisdos a1,b1,c1
print chr$(13,10)
print chr$(13,10)
print chr$(13,10)
mov a1, input("Programa terminado")
ret
Main endp
end start
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder