Algoritmo de cambio de base
Necesitaría un algoritmo en C que se pueda compliar con Borland C++ 4.5, que cambie de cualquier base a cualquier base un numero dado.
1 Respuesta
Respuesta de bebware
1
1
¿Cuándo te refieres a cualquier base, te refieres a las bases usuales? (Binario, octal, decimal, hexadecimal)
Las bases non usuales pueden ser complicadas de programar cuando base > 16. ¿El problema proviene del formalismo... Como representar una base 50? ¿Con letras? ¿Formas?
Especifica un poco mas y tratare ayudarte.
Las bases non usuales pueden ser complicadas de programar cuando base > 16. ¿El problema proviene del formalismo... Como representar una base 50? ¿Con letras? ¿Formas?
Especifica un poco mas y tratare ayudarte.
Ah vale, perdona :) Lo que necesito es un programa que pida un número en la base que se desee, y que dé el resultado en la misma u otra base deseada. Sólo necesito las bases de 1 a 9.
Muchas gracias.
Muchas gracias.
Aqui tienes la solucion a tu problema: solo te queda crear el main y poner los includes necesarios para que te compile Borland C++
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
extern "C" int baseConverter(int number, int base, int newBase)
{
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
return 0;
}
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
extern "C" int baseConverter(int number, int base, int newBase)
{
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
return 0;
}
Hola de nuevo Bebware, perdona por ser pesado :) He intentado varias veces hacer lo que me dijiste, pero no compila. Te dejo el código tal y como lo he intentado compilar, quizá he olvidado añadir o quitar algo.
#include <stdio.h>
#include <string.h>
int main (void)
{
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
baseConverter(int number, int base, int newBase)
{
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
return 0;
}
}
#include <stdio.h>
#include <string.h>
int main (void)
{
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
baseConverter(int number, int base, int newBase)
{
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
return 0;
}
}
No utilizo Borland pero intentalo asi. Lo que te falta son includes... la proxima vez mandame los mensaje de error de compilacion...
#include <sstream>
#include <iostream>
#include <stdio.h>
#include <string.h>
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
int main( int argc, const char* argv[] )
{
int base;
int newBase;
int number;
// ensure the correct number of parameters are used.
if ( argc == 4 )
{
number = atoi( argv[1] );
base = atoi( argv[2] );
newBase = atoi(argv[3]);
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
}
}
#include <sstream>
#include <iostream>
#include <stdio.h>
#include <string.h>
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
int main( int argc, const char* argv[] )
{
int base;
int newBase;
int number;
// ensure the correct number of parameters are used.
if ( argc == 4 )
{
number = atoi( argv[1] );
base = atoi( argv[2] );
newBase = atoi(argv[3]);
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
}
}
Hola de nuevo Bebware. Perdona por tardar tanto. Aquí te dejo otra vez el código y sus errores como me dijiste. Los errores estan abajo del todo. He probado a corregirlos, pero no hay manera, a pesar de que parecen sencillos de solucionar. Bueno, muchas gracias.
#include <sstream.h>
#include <iostream>
#include <stdio.h>
#include <string.h>
int main (void)
{
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
int main( int argc, const char* argv[] )
{
int base;
int newBase;
int number;
// ensure the correct number of parameters are used.
if ( argc == 4 )
{
number = atoi( argv[1] );
base = atoi( argv[2] );
newBase = atoi(argv[3]);
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
}
}
}
Errores:
Compiling BASE.CPP:
Error BASE.CPP 1: Unable to open include file 'SSTREAM.H'
Error BASE.CPP 7: Undefined symbol 'string' in function main()
Error BASE.CPP 7: Statement missing ; in function main()
Error BASE.CPP 54: Compound statement missing } in function main()
Warning BASE.CPP 54: Function should return a value in function main()
#include <sstream.h>
#include <iostream>
#include <stdio.h>
#include <string.h>
int main (void)
{
string convert(int M, int N)
{
//create a stream used for conversion
std::stringstream out;
//if M > N
if (M < N)
{
//No need to continue: Create a new string with the result
out << M;
return string(out.str());
}
else
{
//Compute the modulo and convert it as string
out << M % N;
return convert(M/N, N) + string(out.str());
}
}
int main( int argc, const char* argv[] )
{
int base;
int newBase;
int number;
// ensure the correct number of parameters are used.
if ( argc == 4 )
{
number = atoi( argv[1] );
base = atoi( argv[2] );
newBase = atoi(argv[3]);
//Convert the input number to string
std::stringstream out;
out << number;
string s(out.str());
//convert to base 10
int conversion = 0;
int power = s.length()-1;
for ( unsigned int pos = 0; pos < s.length(); pos++)
{
char digit = s.at(pos);
conversion += atoi(&digit)*(int)pow(base, power);
power--;
}
//convert to the new base
cout << "(" << number << ")" << base << " =" << " (" << convert(conversion, newBase) << ")" << newBase << endl;
}
}
}
Errores:
Compiling BASE.CPP:
Error BASE.CPP 1: Unable to open include file 'SSTREAM.H'
Error BASE.CPP 7: Undefined symbol 'string' in function main()
Error BASE.CPP 7: Statement missing ; in function main()
Error BASE.CPP 54: Compound statement missing } in function main()
Warning BASE.CPP 54: Function should return a value in function main()
Tienes dos metodos main...
Eso no tiene nada que ver con lo que te pase en mi anterior mensaje... vuleve a copiar correctamente y pasame los mensajes de error si hay.
Te prometo que este codigo va perfectamente con 99% de loscompilador existentes...
Cuanto al error de sstream... puede que borland no lo tenga...
Suerte
Eso no tiene nada que ver con lo que te pase en mi anterior mensaje... vuleve a copiar correctamente y pasame los mensajes de error si hay.
Te prometo que este codigo va perfectamente con 99% de loscompilador existentes...
Cuanto al error de sstream... puede que borland no lo tenga...
Suerte
- Compartir respuesta
1 comentario
¿Disculpe ya se resolvió el problema por que si fuera amable que me puedan ayudar con el código? - Luis Ramírez