Documentos de Académico
Documentos de Profesional
Documentos de Cultura
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:
Page 1 of 5
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:
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:
{
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
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:
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