Está en la página 1de 5

SISTEMAS_NUMERACION.

cpp
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:

26/07/2010 05:42:22 p.m.

Page 1 of 5

//--------------------------------------------------------------------------//15 DE JULIO DE 2010


//SISTEMAS DE NUMERACIN
//ING. YASMAN MACHACA
#include <iostream.h>
#include <conio.h>
#include <fstream.h>
#include <vcl.h>
#pragma hdrstop
//--------------------------------------------------------------------------#pragma argsused
#define MAX 20
typedef char cad[MAX];
cad FF,II;
int LONGITUD(cad let);
void G_CERO(int CE,cad KI);
void ESPACIO(int EE,cad PA);
void FHEX(int F,cad XC);
void DEC_DEC(int DEC,cad DD);
void DEC_BIN(int BIN,cad BB);
void DEC_OCT(int OCT,cad OO);
void DEC_HEX(int HEX,cad HH);
void ARABIGO_ROMANO(int ARABIGO,cad QQ);
void INVERTIR(cad WW);
void ADD(cad AA,cad VV);
int main(int argc, char* argv[])
{
int numero;
//nombre del archivo
ofstream Fichero("C_SISTEMAS DE NUMERACION.txt");
//salida en pantalla
cout<<" C++_SISTEMAS DE NUMERACION\n\n";
cout<<" Ingrese un numero : ";
cin>>numero;
cout<<"\nDEC
BIN
BIN10
OCT
HEX
//escribiendo al Fichero
Fichero<<" C++_SISTEMAS DE NUMERACION\n\n";
Fichero<<" Ingrese un numero : "<<numero;
//cin>>numero;
Fichero<<"\n\nDEC
BIN
BIN10
OCT
for (int i = 0; i <= numero; i++)
{
//declarando variables
cad V_DEC="",V_BIN="",V_BIN10="";
cad V_OCT="",V_HEX="",V_ROMANO="";
//variables DEC
DEC_DEC(i,V_DEC);
INVERTIR(V_DEC);
ESPACIO(8,V_DEC);
cout<<V_DEC; //salida en pantalla
Fichero<<V_DEC; //escribiendo Fichero
//variables BIN
DEC_BIN(i,V_BIN);
INVERTIR(V_BIN);
ESPACIO(14,V_BIN);
cout<<V_BIN; //salida en pantalla
Fichero<<V_BIN; //escribiendo Fichero
//variables BIN12
DEC_BIN(i,V_BIN10);
INVERTIR(V_BIN10);
G_CERO(10,V_BIN10);
ESPACIO(14,V_BIN10);
cout<<V_BIN10; //salida en pantalla
Fichero<<V_BIN10; //escribiendo Fichero
//variables OCT
DEC_OCT(i,V_OCT);
INVERTIR(V_OCT);
ESPACIO(8,V_OCT);
cout<<V_OCT; //salida en pantalla
Fichero<<V_OCT; //escribiendo Fichero
//variables HEX

ROMANO\n\n";

HEX

ROMANO\n\n";

SISTEMAS_NUMERACION.cpp
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:

26/07/2010 05:42:22 p.m.

DEC_HEX(i,V_HEX);
INVERTIR(V_HEX);
ESPACIO(7,V_HEX);
cout<<V_HEX; //salida en pantalla
Fichero<<V_HEX; //escribiendo Fichero
//variable ROMANO
ARABIGO_ROMANO(i,V_ROMANO);
cout<<V_ROMANO<<endl; //salida en pantalla
Fichero<<V_ROMANO<<endl; //escribiendo Fichero
}
cout<<"\nFIN DEL PROGRAMA...\n"; //salida en pantalla
Fichero<<"\nFIN DEL PROGRAMA...\n"; //escribiendo Fichero
Fichero.close();
getch();
return 0;
}
void FHEX(int F,cad XC)
{
switch (F)
{
case 0:
ADD(XC,"0");
break;
case 1:
ADD(XC,"1");
break;
case 2:
ADD(XC,"2");
break;
case 3:
ADD(XC,"3");
break;
case 4:
ADD(XC,"4");
break;
case 5:
ADD(XC,"5");
break;
case 6:
ADD(XC,"6");
break;
case 7:
ADD(XC,"7");
break;
case 8:
ADD(XC,"8");
break;
case 9:
ADD(XC,"9");
break;
case 10:
ADD(XC,"A");
break;
case 11:
ADD(XC,"B");
break;
case 12:
ADD(XC,"C");
break;
case 13:
ADD(XC,"D");
break;
case 14:
ADD(XC,"E");
break;
case 15:
ADD(XC,"F");
break;
}
}
void DEC_DEC(int DEC,cad DD)

Page 2 of 5

SISTEMAS_NUMERACION.cpp
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:
176:
177:
178:
179:
180:
181:
182:
183:
184:
185:
186:
187:
188:
189:
190:
191:
192:
193:
194:
195:
196:
197:
198:
199:
200:
201:
202:
203:
204:
205:
206:
207:
208:
209:
210:
211:
212:
213:
214:
215:
216:

26/07/2010 05:42:22 p.m.

{
int R,D=DEC;
while (D>0)
{
cad MM="";
R=D%10;
D=D/10;
FHEX(R,MM);
ADD(DD,MM);
}
if (DEC==0)
{
ADD(DD,"0");
}
}
void DEC_BIN(int BIN,cad BB)
{
int R,B=BIN;
while (B>0)
{
cad MM="";
R=B%2;
B=B/2;
FHEX(R,MM);
ADD(BB,MM);
}
if (BIN==0)
{
ADD(BB,"0");
}
}
void DEC_OCT(int OCT,cad OO)
{
int R,O=OCT;
while (O>0)
{
cad MM="";
R=O%8;
O=O/8;
FHEX(R,MM);
ADD(OO,MM);
}
if (OCT==0)
{
ADD(OO,"0");
}
}
void DEC_HEX(int HEX,cad HH)
{
int R,H=HEX;
while (H>0)
{
cad MM="";
R=H%16;
H=H/16;
FHEX(R,MM);
ADD(HH,MM);
}
if (HEX==0)
{
ADD(HH,"0");
}
}
void ARABIGO_ROMANO(int ARABIGO,cad QQ)
{
int H;
H=ARABIGO;
if (ARABIGO!=0)
{
while (H>=1000)
{
H=H-1000;

Page 3 of 5

SISTEMAS_NUMERACION.cpp

26/07/2010 05:42:22 p.m.

217:
ADD(QQ,"M");
218:
}
219:
while (H>=900)
220:
{
221:
H=H-900;
222:
ADD(QQ,"CM");
223:
}
224:
while (H>=500)
225:
{
226:
H=H-500;
227:
ADD(QQ,"D");
228:
}
229:
while (H>=400)
230:
{
231:
H=H-400;
232:
ADD(QQ,"CD");
233:
}
234:
while (H>=100)
235:
{
236:
H=H-100;
237:
ADD(QQ,"C");
238:
}
239:
while (H>=90)
240:
{
241:
H=H-90;
242:
ADD(QQ,"XC");
243:
}
244:
while (H>=50)
245:
{
246:
H=H-50;
247:
ADD(QQ,"L");
248:
}
249:
while (H>=40)
250:
{
251:
H=H-40;
252:
ADD(QQ,"XL");
253:
}
254:
while (H>=10)
255:
{
256:
H=H-10;
257:
ADD(QQ,"X");
258:
}
259:
while (H>=9)
260:
{
261:
H=H-9;
262:
ADD(QQ,"IX");
263:
}
264:
while (H>=5)
265:
{
266:
H=H-5;
267:
ADD(QQ,"V");
268:
}
269:
while (H>=4)
270:
{
271:
H=H-4;
272:
ADD(QQ,"IV");
273:
}
274:
while (H>=1)
275:
{
276:
H=H-1;
277:
ADD(QQ,"I");
278:
}
279:
}
280:
else
281:
{
282:
ADD(QQ," ");
283:
}
284: }
285: void ADD(cad AA,cad VV)
286: {
287:
int La,Lv;
288:
La=LONGITUD(AA);

Page 4 of 5

SISTEMAS_NUMERACION.cpp
289:
290:
291:
292:
293:
294:
295:
296:
297:
298:
299:
300:
301:
302:
303:
304:
305:
306:
307:
308:
309:
310:
311:
312:
313:
314:
315:
316:
317:
318:
319:
320:
321:
322:
323:
324:
325:
326:
327:
328:
329:
330:
331:
332:
333:
334:
335:
336:
337:
338:
339:
340:
341:
342:
343:
344:
345:
346:
347:
348:
349:
350:
351:
352:
353:

26/07/2010 05:42:22 p.m.

Lv=LONGITUD(VV);
for (int i = 0; i < Lv; i++)
{
AA[i+La]=VV[i];
}
}
int LONGITUD(cad let)
{
int i=0;
while ((let[i]!='\0')&&(let[i]!=' '))
{
i++;
}
return i;
}
void INVERTIR(cad WW)
{
int Lw,j=0;
cad JJ="";
Lw=LONGITUD(WW);
for (int i = Lw-1; i >=0; i--,j++)
{
JJ[j]=WW[i];
}
for (int i = 0; i < Lw; i++)
{
WW[i]=JJ[i];
}
}
void ESPACIO(int EE,cad PA)
{
int N,Lpa;
if (EE<MAX)
{
Lpa=LONGITUD(PA);
N=EE-Lpa;
}
else
{
Lpa=LONGITUD(PA);
N=19-Lpa;
}
for (int i = 0; i < N; i++)
{
PA[i+Lpa]=' ';
}
}
void G_CERO(int CE,cad KI)
{
int Lki,N;
cad CC="";
ADD(CC,KI);
Lki=LONGITUD(KI);
N=CE-Lki;
for (int i = 0; i < N; i++)
{
KI[i]='0';
}
for (int i = 0; i < Lki; i++)
{
KI[i+N]=CC[i];
}
}
//---------------------------------------------------------------------------

Page 5 of 5

También podría gustarte