Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Центр помощи > [C] Разбиваем число


Автор: ressac 23.12.2006, 00:27
хай всем.

ну вот у нас например есть число 1234, и нам надо отделить одну цифру от другой

вот мой код, но он действует только для чисел которые не превышают 10-и цифорвый значения.
Код

#include <stdio.h>

main()
{
 int divb,i=1; long datoi; double dato,div=1;
 
 printf("\nEnter the number: "), scanf("%lf",&dato);
 for(;dato>=div;div*=10);div/=10;
 for(;div>=1;div/=10,i++)
 {
  datoi=dato/div,datoi=datoi%10;
  printf("%d,",datoi);
 }
printf("\n");
system("pause");
}



вся проблема в том что модуль (%) не хочет работать с double или float компилятор (я использую gcc) мне говорит "invalid operands to binary %", a long макс подериживает 10 значные значения smile

как решить проблему smile 

спасиб всем за ранее ;)

Автор: skyboy 23.12.2006, 01:58
обойти её с той точки зрения, что x % y == x - floor(x / y) * y

Автор: ressac 23.12.2006, 02:34
skyboy
ничё не понял smile можно разжевать? smile

Автор: V.A.KeRneL 23.12.2006, 10:26
ressac, а что не понятно-то?
ОСТАТОК_ОТ_ДЕЛЕНИЯ == ДЕЛИМОЕ - ЦЕЛАЯ_ЧАСТЬ[ОТ_ЧАСТНОГО]*ДЕЛИТЕЛЬ.
Например, 10%3 = 10 - [10/3]*3 = 10 - 3*3 = 1.

Автор: apook 23.12.2006, 12:34
datoi =datoi-((datoi /10) *10);
//еквивалент
datoi =datoi %10;

Автор: Dov 23.12.2006, 12:58
Цитата(V_A_KeRneL @  23.12.2006,  09:26 Найти цитируемый пост)
а что не понятно-то?

Не понятно следующее. Есть число: 
Код
float num = 0,012345;
 Далее читаем название темы и объясняем человеку, каким образом, всё написаное выше, можно применить.  smile 

Автор: skyboy 23.12.2006, 13:02
Цитата(Dov @  23.12.2006,  11:58 Найти цитируемый пост)
Далее читаем название темы и объясняем человеку, каким образом, всё написаное выше, можно применить. 

речь шла о целых числах. если это кажется неочевидным, то поясню, что в общем случае парсинг дробных чисел бесконечен:
"float num = 0,012345;" будет представлено, как "0","0","1","2","3","4","5","0","0","0","0","0","0","0"....
потому надо было говорить о точности разложения(в двочиной СС конечная десятичная дробь будет бесконечной, потому надо определить, до каких пор разделять цифры), раз сказано не было - речь о целых числах.

Автор: Dov 23.12.2006, 13:21
Цитата(ressac @  22.12.2006,  23:27 Найти цитируемый пост)
вся проблема в том что модуль (%) не хочет работать с double или float

Если это целые, то да. smile 


Автор: skyboy 23.12.2006, 15:15
Цитата(Dov @  23.12.2006,  12:21 Найти цитируемый пост)
Если это целые, то да

в типе float уже низзя хранить целые рациональные числа?  smile 

Автор: Oleg_Ci 23.12.2006, 15:30
Задача пустятская smile 
Код

#include <stdio.h>

/////////////// main ///////////////////
int main(int argc, char *argv[])

    int divb ,i=1; long datoi; double dato,div=1;
 
    printf("\nEnter the number: "), scanf("%lf",&dato);

    for(;dato>=div;div*=10);
    div/=10;
    for(;div>=1;div/=10,i++)
    {
        datoi=dato/div,datoi=datoi%10;
        printf("%d,",datoi);
    }
    /////////// Вот ОНО /////////////
    for( div=10;; div*=10 )
    {
        datoi=dato*div;
        datoi=datoi%10;
        if( !datoi ) break;
        printf("%d,",datoi);
    }
    ////////////////////////////////////////////
    fflush(stdin);
    getchar(); // пауза
    return 0;
}

Автор: Dov 23.12.2006, 15:57
Цитата(Олег4 @  23.12.2006,  14:30 Найти цитируемый пост)
Задача пустятская

Олег4, человеку нужно посчитать количество знаков после запятой, например: 
Код

123,456789
 Здесь 6 знаков.  smile 


Автор: Oleg_Ci 23.12.2006, 16:03
с исправлениями  smile 
Код

#include <stdio.h>

/////////////// main ///////////////////
int main(int argc, char *argv[])

    int divb ,i=1; long datoi; double dato,div=1;
 
    printf("\nEnter the number: "), scanf("%lf",&dato);

    for(;dato>=div;div*=10);
    div/=10;
    for(;div>=1;div/=10,i++)
    {
        datoi=dato/div,datoi=datoi%10;
        printf("%d,",datoi);
    }
    /////////// Вот ОНО /////////////
    for( div=10, i=0;; div*=10 )
    {
        i++;
        datoi=dato*div;
        datoi=datoi%10;
        printf("%d,",datoi);
        double r = (double)(dato*div) - (int)(dato*div);
        if( r == 0 ) break;
    }
    printf("\n\nCount = %d", i );
    ////////////////////////////////////////////
    fflush(stdin);
    getchar(); // пауза
    return 0;
}


Добавлено @ 16:11 
Не, вот так надо smile 
Код

/////////// Вот ОНО /////////////
for( div=10, i=0;((double)(dato*div/10) - (int)(dato*div/10)); div*=10, i++ )
{
        datoi=dato*div;
        datoi=datoi%10;
        printf("%d,",datoi);
}
printf("\n\nCount = %d", i );
////////////////////////////////////////////

Автор: Dov 23.12.2006, 16:36
Цитата(Олег4 @  23.12.2006,  15:03 Найти цитируемый пост)
Не, вот так надо


Олег4, хоть так, хоть так, всё равно не работает.  smile 

Автор: Oleg_Ci 23.12.2006, 17:47
Всё работает.
Вводим число -> 1.204
результат  -> 1,2,0,4,
количество цифр после запятой -> count = 3

У меня ms2003 и у меня работает smile 

Автор: Dov 23.12.2006, 18:20
Цитата(Олег4 @  23.12.2006,  16:47 Найти цитируемый пост)
У меня ms2003 и у меня работает 

Ну, тогда введи так: 22222.11111

Автор: ressac 23.12.2006, 18:47
В ЭТОЙ ТЕМЕ РЕЧЬ ИДЁТ О ЦЕЛЫХ ЧИСЛАХ, БЕЗ ДРОБЕЙ.
если кто-то хочет ещё мозги подолбать с дробями то тут http://forum.vingrad.ru/topic-128228/0.html есть эта тема smile

Олег4, твоя прога считает до 10 цифр но не более , не знаю что она делает ещё толком не вникал.  А если я напишу ещё цифры после запятой то она начинает бесконечный цикл smile

Автор: Dov 23.12.2006, 19:23
Цитата(ressac @  23.12.2006,  17:47 Найти цитируемый пост)
В ЭТОЙ ТЕМЕ РЕЧЬ ИДЁТ О ЦЕЛЫХ ЧИСЛАХ, БЕЗ ДРОБЕЙ.


ressac, тогда ответь на один простой вопрос. 
В переменной какого типа ты хранишь то число, которое нужно разбить на цифры?  smile 

Автор: ressac 23.12.2006, 19:36
храню в double так как в него может влезть больше чем 10 значное число...
затем делю и переношу в long затем из него при помощи модуля вытаскиваю последнюю цифру и так по кругу, но когда мы перешагиваям через 10 цифру тут и начинаются все проблемы, понимаешь меня? 

Автор: Dov 23.12.2006, 20:46
ressac, а почему ты не хочешь хранить в символьной строке?

Автор: ressac 23.12.2006, 21:40
Dov, ты про char? 

если да, то как я потом буду из чара вытаскивать это число что я ввел ? мне же потом с ним надо будет ещё и операции выполнять...

вообще растолкуй свой метод, если не сложно, мне интересно.


кстати сходи в тему с дробями там я выложил готовый исходник (+/- работает правильно правда иногда или на одну цифру больше даёт или меньше) smile  
и там-же кстати в середине темы, есть способ с чаром.

Автор: Rockie 23.12.2006, 23:48
Цитата(ressac @  23.12.2006,  21:40 Найти цитируемый пост)
если да, то как я потом буду из чара вытаскивать это число что я ввел ? 

ressac, функцией strtol к примеру
Код
// crt_strtod.c
// This program uses strtod to convert a
// string to a double-precision value; strtol to
// convert a string to long integer values; and strtoul
// to convert a string to unsigned long-integer values.
//

#include <stdlib.h>
#include <stdio.h>

int main( void )
{
   char   *string, *stopstring;
   double x;
   long   l;
   int    base;
   unsigned long ul;

   string = "3.1415926This stopped it";
   x = strtod( string, &stopstring );
   printf( "string = %s\n", string );
   printf("   strtod = %f\n", x );
   printf("   Stopped scan at: %s\n\n", stopstring );

   string = "-10110134932This stopped it";
   l = strtol( string, &stopstring, 10 );
   printf( "string = %s\n", string );
   printf("   strtol = %ld\n", l );
   printf("   Stopped scan at: %s\n\n", stopstring );

   string = "10110134932";
   printf( "string = %s\n", string );
 
   // Convert string using base 2, 4, and 8:
   for( base = 2; base <= 8; base *= 2 )
   {
      // Convert the string:
      ul = strtoul( string, &stopstring, base );
      printf( "   strtol = %ld (base %d)\n", ul, base );
      printf( "   Stopped scan at: %s\n", stopstring );
   }
}

 
Цитата
Output
  
string = 3.1415926This stopped it
   strtod = 3.141593
   Stopped scan at: This stopped it

string = -10110134932This stopped it
   strtol = -2147483648
   Stopped scan at: This stopped it

string = 10110134932
   strtol = 45 (base 2)
   Stopped scan at: 34932
   strtol = 4423 (base 4)
   Stopped scan at: 4932
   strtol = 2134108 (base 8)
   Stopped scan at: 932




Автор: ressac 23.12.2006, 23:50
вот доработал по теории всё должно быть хорошо ну выходить всё не так, иногда есть взбои, и всё потому что дроби врут smile...


Код

#include <stdio.h>
main()
{
 int i=1; long datoi; double dato,div=1;
 
 printf("\nEnter the number: "), scanf("%lf",&dato);
 for(;dato>=div;div*=10);div/=10;
 for(;div>=1;div/=10,i++)
 {
                  printf("\n//------------------------\n");
                  printf("\nI:%d\n",i);
  datoi=dato/div; printf("\n%d\n",datoi);
  datoi=datoi%10; printf("\n%d\n",datoi);
                  printf("\n\%lf\n",dato/div);
                  printf("\n\%lf\n",div);
  
   dato/=div;
   dato-=(int)dato;
   dato*=div;

  system("pause");
  //printf("%d,",datoi);
 }
printf("\n");
system("pause");
}

 

Автор: Dov 24.12.2006, 22:28
Цитата(ressac @  23.12.2006,  20:40 Найти цитируемый пост)
Dov, ты про char? если да, то как я потом буду из чара вытаскивать это число что я ввел ? мне же потом с ним надо будет ещё и операции выполнять...вообще растолкуй свой метод, если не сложно, мне интересно.


ressac, вот тебе ответ на все твои вопросы:
Код
#include <stdio.h>

int main()
{
    char   str_num[81];
    double dbl_num;

    printf("\nEnter the number:\n\t");

    // вводишь строку символов, например: 0,012345678987654321234567898765432123456789 
    scanf ("%s", str_num);

    // работаешь с этой строкой, как я показал в той теме
    // ...

    // получаешь число типа double из этой строки
    sscanf(str_num, "%lf", &dbl_num);
    // или так, как Rockie предложил 
    // dbl_num = strtod(str_num, NULL);
    
    // работаешь с числом
    // ...

    printf("string: %s\ndouble: %g\n\n", str_num, dbl_num);

    return 0;
}

Автор: ressac 25.12.2006, 00:19
Dov

спасиб. ;)


жаль что не получилось как я хотел, но я всё-таки думаю что есть способ это сделать с реальными числами... без внедрения чара и тому подобных вещей.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)