Модераторы: Daevaorn

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Реверс цыфр в числе, Функция реверсирует порядок цифр 
V
    Опции темы
GSasha
Дата 22.1.2009, 19:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 23.3.2008
Где: Ukraine

Репутация: нет
Всего: нет



Есть задание:
There is number e.g. 6789 it needs to write function, which returns vise versa number – 9876.
Мой вариант таковой
Код

int ReverseNum( int n )
{
    int nRes = 0;

    while ( n )
    {
        int nCurrent = n % 10;

        nRes *= 10;
        nRes += nCurrent;
        n /= 10;      
    }

    return nRes;
}

Возможно ли улучшить данный вариант (без использования atoi и itoa)?
PM MAIL ICQ   Вверх
Kallikanzarid
Дата 23.1.2009, 04:00 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 240
Регистрация: 9.11.2008

Репутация: нет
Всего: 3



Для десятичных чисел, ИМХО, нет. Для 16-х и 2-х - можно.
PM MAIL   Вверх
mes
Дата 23.1.2009, 04:17 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 144
Всего: 250



Цитата(GSasha @  22.1.2009,  18:39 Найти цитируемый пост)

Возможно ли улучшить данный вариант

разве что только избавиться от лишней переменной и облегчить цикл :
Код

int ReverseNum( int n )
{
    int nRes = 0;
    for (; n;  n /= 10  )
         nRes *= 10,  nRes += n % 10;

    return nRes;
}


П.С. код не при больших значениях  будет выдавать неверный результат в следствии переполнения..




--------------------
PM MAIL WWW   Вверх
GSasha
  Дата 23.1.2009, 08:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 23.3.2008
Где: Ukraine

Репутация: нет
Всего: нет



ок, всем спасибо. smile 
PM MAIL ICQ   Вверх
mrbrooks
Дата 23.1.2009, 08:40 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

Репутация: 2
Всего: 306



GSasha, а ты число вводишь с клавиатуры или оно у тебя жестко забито в программе?
PM MAIL   Вверх
GoldFinch
Дата 23.1.2009, 09:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата



****


Профиль
Группа: Завсегдатай
Сообщений: 2141
Регистрация: 30.11.2008

Репутация: 15
Всего: 26



можно загрузить в fpu, преобразовать в bcd, поменять байты местами, загрузить в fpu, записать на место
неисключено что это даже быстрее цикла
PM MAIL ICQ   Вверх
GSasha
Дата 23.1.2009, 09:31 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 23.3.2008
Где: Ukraine

Репутация: нет
Всего: нет



Цитата(mrbrooks @  23.1.2009,  08:40 Найти цитируемый пост)
а ты число вводишь с клавиатуры или оно у тебя жестко забито в программе? 

с клавиатуры
Код

 int n;
 cin >> n;
 cout << ReverseNum( n );


Добавлено через 4 минуты и 7 секунд
Цитата(GoldFinch @  23.1.2009,  09:28 Найти цитируемый пост)
можно загрузить в fpu, преобразовать в bcd, поменять байты местами, загрузить в fpu, записать на место
неисключено что это даже быстрее цикла 

 smile  smile 
PM MAIL ICQ   Вверх
mrbrooks
Дата 23.1.2009, 09:47 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


трололомен
****


Профиль
Группа: Завсегдатай
Сообщений: 4259
Регистрация: 4.10.2006
Где: Дол Гулдур

Репутация: 2
Всего: 306



Код

#include <stdio.h>
#include <string.h>

int main() {
    char str[50];
    scanf( "%s", str );
    _strrev( *str == '-' ? str + 1 : str );
    printf( "%s\n", str );
}


Добавлено @ 09:53
с потоками ввода/вывода
Код

#include <iostream>
#include <string.h>

int main() 
{
    char str[50];
    std::cin.getline(str, sizeof(str)+1);
    _strrev(*str == '-'?str+1:str);
    std::cout << str;
    std::cin.get();
    return 0;
}


Это сообщение отредактировал(а) mrbrooks - 23.1.2009, 09:55
PM MAIL   Вверх
GoldFinch
Дата 23.1.2009, 12:56 (ссылка)    | (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата



****


Профиль
Группа: Завсегдатай
Сообщений: 2141
Регистрация: 30.11.2008

Репутация: 15
Всего: 26



для 8 цифр
Код

int foo(int x)
{
char bcd[10];
__asm{
  fild dword ptr [x]
  fbstp dword ptr [bcd]
  pop eax
  pop edx
  bswap eax
  bswap edx
  push eax
  push edx
  fbld dword ptr [bcd]
  fistp dword ptr [bcd]
  pop eax
}}

PM MAIL ICQ   Вверх
mes
Дата 23.1.2009, 14:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


любитель
****


Профиль
Группа: Участник Клуба
Сообщений: 7954
Регистрация: 14.1.2006

Репутация: 144
Всего: 250



Цитата(GSasha @  22.1.2009,  18:39 Найти цитируемый пост)

Возможно ли улучшить данный вариант


Цитата(GoldFinch @  23.1.2009,  11:56 Найти цитируемый пост)
для 8 цифр

Улучшения не вижу ... код стал непереносим, да и не под каждый компилятор, к тому же и программисту в нагрузку на память...



--------------------
PM MAIL WWW   Вверх
Dov
Дата 23.1.2009, 15:04 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


аСинизатор
***


Профиль
Группа: Завсегдатай
Сообщений: 1721
Регистрация: 10.5.2003
Где: Эрец-Исраэль

Репутация: 15
Всего: 88



Цитата(GSasha @  22.1.2009,  18:39 Найти цитируемый пост)
Возможно ли улучшить данный вариант (без использования atoi и itoa)?

Не знаю, что ты имеешь ввиду под словом "улучшить" , но могу предложить такой вариант:
Код
int ReverseNum( int n )
{
    int  nRes;
    char buf[11];

    sprintf(buf, "%d", n);
    sscanf(_strrev(buf), "%d", &nRes);   

    return nRes;
}




--------------------
Тут вечности запах томительный,
И свежие фрукты дешевые, 
А климат у нас – изумительный, 
И только соседи – #уевые. 
                           Игорь Губерман.
PM   Вверх
jonie
Дата 23.1.2009, 15:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 15
Всего: 118



на скорость увеличить можно, при условиях ограниченности чисел - можно сделать таблицу предрасчитанных значений 8)
много памяти, зато быстро должно быть...


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
GSasha
Дата 23.1.2009, 16:23 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 23.3.2008
Где: Ukraine

Репутация: нет
Всего: нет



Цитата(Dov @  23.1.2009,  15:04 Найти цитируемый пост)
но могу предложить такой вариант:

хороший вариант, имхо
и красиво смотрится
PM MAIL ICQ   Вверх
jonie
Дата 23.1.2009, 16:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
****


Профиль
Группа: Завсегдатай
Сообщений: 5613
Регистрация: 21.8.2005
Где: Владимир

Репутация: 15
Всего: 118



и чем это он хороший ?


--------------------
Что-то не поняли? -> Напейтесь до зеленых человечков... эта сверхцивилизация Вам поможет...
PM MAIL Jabber   Вверх
GSasha
Дата 23.1.2009, 17:07 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 77
Регистрация: 23.3.2008
Где: Ukraine

Репутация: нет
Всего: нет



Цитата(jonie @  23.1.2009,  16:39 Найти цитируемый пост)
и чем это он хороший ? 

А чем не хороший?
PM MAIL ICQ   Вверх
Ответ в темуСоздание новой темы Создание опроса
Правила форума "С++:Общие вопросы"
Earnest Daevaorn

Добро пожаловать!

  • Черновик стандарта C++ (за октябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика(4.4мб).
  • Черновик стандарта C (за сентябрь 2005) можно скачать с этого сайта. Прямая ссылка на файл черновика (3.4мб).
  • Прежде чем задать вопрос, прочтите это и/или это!
  • Здесь хранится весь мировой запас ссылок на документы, связанные с C++ :)
  • Не брезгуйте пользоваться тегами [code=cpp][/code].
  • Пожалуйста, не просите написать за вас программы в этом разделе - для этого существует "Центр Помощи".
  • C++ FAQ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, Earnest Daevaorn

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | C/C++: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1204 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.