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

Алгоритм перевода чисел - C++

Восстановить пароль Регистрация
 
Frosty37
Сообщений: n/a
18.05.2011, 23:28     Алгоритм перевода чисел #1
Помогите пожалуйста! Надо мне написать алгоритм перевода из десятичного числа в 16 ричное число!
Через стандартные функции не катит,и через указатели тоже! Он должен быть самым простым алгоритмом! Вот как реализовать это програмно: залаем с клавиатуры число,делим его на 16,записываем остаток,потом сравниваем если число равно от 1 до 10 то ничего не менять,а если больше 10 то записать букву! Что то типа в этом роде! Только самый простой вариант! Помогите прошу! В голове не укладывается!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Mиxaил
 Аватар для Mиxaил
530 / 435 / 37
Регистрация: 10.12.2009
Сообщений: 1,857
18.05.2011, 23:50     Алгоритм перевода чисел #2
все проще... взял с этого поста: (реализация Си)
C
1
2
3
4
5
6
#include <stdio.h>
int main()
{
 printf ("%x\n", 100);
 getchar ();
}
kazak
 Аватар для kazak
3029 / 2350 / 155
Регистрация: 11.03.2009
Сообщений: 5,401
19.05.2011, 03:24     Алгоритм перевода чисел #3
Mиxaил, внимательно читать надо: через стандартные функции не катит.
diagon
Higher
 Аватар для diagon
1920 / 1186 / 49
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
19.05.2011, 07:52     Алгоритм перевода чисел #4
Длинка
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
#include <iostream>
#include <sstream>
#include <vector>
#include <algorithm>
#include <conio.h>
struct div_result{
    std::vector<int> div;
    long long mod;
};
void readlong(std::vector<int> &a){
    std::string s;
    std::cin >> s;
    for (std::string::iterator i = s.end()-1; i >= s.begin(); i--)
        a.push_back(*i-48);
}
void writelong(std::vector<int> a){
    for (std::vector<int>::iterator i=a.end()-1; i >= a.begin(); i--)
        switch (*i) {
        case 10:std::cout << 'A';   break;
        case 11:std::cout << 'B';   break;
        case 12:std::cout << 'C';   break;
        case 13:std::cout << 'D';   break;
        case 14:std::cout << 'E';   break;
        case 15:std::cout << 'F';   break;
        default:std::cout << *i;
        }
}
div_result div(std::vector<int> a,long long b){
    div_result q;
    std::vector<int> c;
    bool k=false;
    long long x=0;
    for (int i=a.size()-1;i>=0; i--){
        x=x*10+a[i];
        if (x<b&&!k&&i) continue;
        k=true;
        c.push_back(x/b);
        x%=b;
    }
    std::reverse(c.begin(),c.end());
    q.div.assign(c.begin(),c.end());
    q.mod=x;
    return q;
}
std::vector<int> to16(std::vector<int> a){
    std::vector<int> c; //результат
    for (;;) {
        if (a.size()==1) {c.push_back(*a.begin()); break;}  //если осталась одна цифра заносим число в начало
        if(a.size()==2&&a[1]==1&&a[0]<6) {c.push_back(a[1]*10+a[0]); ; break;}//если 2 цифры, но число меньше 16, то тоже самое
        c.push_back(div(a,16).mod);    //ложим в результат остаток от деления a на 16
        a=div(a,16).div;   //делим а на 16
        if (a.back()==0) a.pop_back();  //если в начале числа получился 0, то убираем его
    }
    return c;
}
int main(){
    std::vector <int> a;
    readlong(a);
    writelong(to16(a));
    getch();
    return 0;
}
На краткость кода не претендую, но алгоритм там простой(тупо деление числа на 16)
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4236 / 2769 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
19.05.2011, 08:24     Алгоритм перевода чисел #5
Цитата Сообщение от Frosty37 Посмотреть сообщение
Вот как реализовать это програмно: залаем с клавиатуры число,делим его на 16,записываем остаток,потом сравниваем если число равно от 1 до 10 то ничего не менять,а если больше 10 то записать букву! Что то типа в этом роде! Только самый простой вариант!
Держи)
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <iostream>
void dec_to_hex(int);
int main(){
    int n;
    std::cout<<"Enter digit: ";
    std::cin>>n;
    dec_to_hex(n);
    std::cout<<std::endl;
    return 0;
}
void dec_to_hex(int n){
    if(!(n/16)){
        std::cout<<(n%16<10 ? char(n+'0'):char(n+'A'-10));
        return;
    }
    dec_to_hex(n/16);
    std::cout<<(n%16<10 ? char(n%16+'0'):char(n%16+'A'-10));
}
taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
19.05.2011, 08:51     Алгоритм перевода чисел #6
Mиxaил, это не алгоритм перевода.
taras atavin
Ушёл с форума.
 Аватар для taras atavin
3569 / 1752 / 91
Регистрация: 24.11.2009
Сообщений: 27,619
19.05.2011, 09:11     Алгоритм перевода чисел #7
Frosty37, кажется, так:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
string Hex(int x)
{
 static digits[17]="0123456789ABCDEF";
 string result;
 if (x==0)
 {
  result='0';
 }
 else
 {
  for (result=""; x!=0; x=16, --n)
  {
   result=digits[x%16]+result;
  }
 }
 return result;
}
, но я не уверен на счёт строки
C++
1
result=digits[x%16]+result;
, так как не знаю, можно ли к строке слева конкатенировать символ.
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
19.05.2011, 13:23     Алгоритм перевода чисел
Еще ссылки по теме:

Программа перевода чисел C++
C++ Алгоритм перевода шестнадцатеричного числа в десятичный код
C++ Алгоритм Брезенхема. Проверьте корректность перевода (C++ -> Delphi)

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
rangerx
1908 / 1517 / 139
Регистрация: 31.05.2009
Сообщений: 2,876
19.05.2011, 13:23     Алгоритм перевода чисел #8
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include <iostream>
#include <string>
 
void Hex(unsigned long int src, std::string& dest)
{
    const char digits[]= {'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};
    const unsigned long int q = 16;
 
    dest.clear();
    do dest.insert(0, 1, digits[src % q]); while(src/= q);
}
 
int main()
{
    unsigned long int val;
    std::cin >> val;
 
    std::string hexStr;
    Hex(val, hexStr);
    std::cout << hexStr << '\n';
 
    return 0;
}
Yandex
Объявления
19.05.2011, 13:23     Алгоритм перевода чисел
Ответ Создать тему
Опции темы

Текущее время: 09:24. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru