Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Перевод из n-ричной системы счисления, в k-ричную - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ if в C++ и C http://www.cyberforum.ru/cpp/thread262941.html
Как использовать оператор if в С++ и С ? Напимер: JavaScript if (условие) { тогда } else {}
C++ скачать c++ Где можно скачать НОРМАЛЬНЫЙ C++? на Windiws 7 http://www.cyberforum.ru/cpp/thread262855.html
C++ Опциональный вызов деструктора в шаблоне
Разбираясь с шаблонами, решил описать набор шаблонов для работы с матрицами. Выделение памяти, применение операции к каждому элементу и освобождение памяти. При освобождении памяти, если элемент...
Функции C++
Убрать из первой строки все символы, входящие во вторую строку уже окончательно запутался помогите пожалуйста
C++ Скоро аттестация, а программы написать все не могу((( http://www.cyberforum.ru/cpp/thread262032.html
Скоро будут ставить аттестацию, а программы написать не могу - плохо усвоил тему((. Помогите написать 3 программы на обработку строк на языке С++: 1)Дана строка символов. Выяснить имеется ли в...
C++ Генерация программного кода по xml файлу Всем добрый день. Пишу дипломный проект - программу, позволяющую из блоков, подобных UML блокам составлять простые алгоритмы (линейные, условные и циклические) и выполнять их. Одной из обязательных... подробнее

Показать сообщение отдельно
iama
1250 / 975 / 49
Регистрация: 30.07.2010
Сообщений: 5,297

Перевод из n-ричной системы счисления, в k-ричную - C++

24.03.2011, 21:52. Просмотров 1627. Ответов 1
Метки (Все метки)

Сабж. Само число не превышает 2^31, писал так:
C++
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
#include <iostream>
#include <string>
#include <math.h>
 
using namespace std;
using std::string;
 
int from(char c)
{
  if (c > '9') return (int) c - 54;
  else return (int) c - 48;
}
 
char out(int n)
{
  if (n > 9) return (char) (n + 55);
  else return (char) (n + 48);
}
 
int main()
{
  long long p, n, k, i, l; string a, b = "";
 
  cin >> n >> a >> k;
  l = a.length();
  p = 0;
 
  for (i = 0; i < l; i++)
    p += pow(n, i) * from(a[l-i-1]);
 
  while (p) {
    b = out(p % k) + b;
    p /= k;
  }
 
  cout << b;
  if (b == "") cout << '0';
 
  return 0;
}
помогите с тестированием

Добавлено через 4 минуты
Уже нашел, удалите тему, извините, засоряю
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru