2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
1

Отбрасывание незначащих нулей

18.03.2013, 05:10. Показов 8481. Ответов 11
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
как сделать чтобы программа отбрасывала незначащие нули после запятой в строке (string)
Например вводим строку a = 156,870000000000
а на выводе получаем а = 156,87
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
18.03.2013, 05:10
Ответы с готовыми решениями:

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

Отбрасывание дробной части числа при делении
double x = 5 / 2; cout << x; выводит не 2.5, а 2 в чем дело? как исправить? помогите плиз :(

Как сделать округление/отбрасывание ненужных цифр после запятой?
Как сделать округление/отбрасывание ненужных цифр после запятой? Вот например код: double a =...

Найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц
Нужно найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц. В чем...

11
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 876
Записей в блоге: 10
18.03.2013, 05:38 2
Пока Синтаксис строки форматирования
1
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
18.03.2013, 05:53  [ТС] 3
немножко не так написал
нужно отбросить нули для дальнейших операций со строкой.(подсчет размера,поиск элемента,ограничение количества вводимых символов)
например мне нужно ввести число состоящее из шести значащих цифр.
Если ограничить вводимый диапазон до шести знаков и ввести 63,22000000 ,то будет ошибка, а нужно чтобы было правильно. Вот и задача отбросить эти нули
0
Заблокирован
18.03.2013, 06:09 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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define buf 50
 
int main()
{   char s1[buf], s2[buf];
    int len1,len2;
    
    printf("s1 = ");
    scanf("%s",s1);
    strcpy(s2,s1);
 
    len2 = len1 = strlen(s1);
    while(s1[len2-1]=='0')
        len2--;
    s2[len2]='\0';
 
    printf("s2 = %s",s2);
 
    flushall();getchar();
    return 0;
}
1
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 876
Записей в блоге: 10
18.03.2013, 06:13 5
Не совсем понял. Assuming есть число и нужно из него получить строку. Вот этот reference лакончинее. Переложите для sprintf если нужно получить строку, а не выводить на консоль. Прогоните следующий код, может, прояснится.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h>
 
void myprint( double x );
 
void main()
{
    myprint( 2.0 );
    myprint( 2.1 );
    myprint( 2.0000001 );
    myprint( 123.0 );
    myprint( 12300000.1 );
    myprint( 0.000000000123 );
    getchar();
}
 
void myprint( double x )
{
    printf( "e: %e\tf: %f\tg: %g\n", x, x, x ); 
}
Добавлено через 3 минуты
masikus, скажите, как Вы хотите поступать с числами вроде 123000000.1 и 0.00000000123? Они форматируются в 1.23e+008 и 1.23e-009.

Добавлено через 43 секунды
Я понял свою ошибку, сейчас отпишусь.
1
What a waste!
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
18.03.2013, 06:25 6
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
 
 
int main() {
   std::string a = "156,870000000000";
    
   std::string::reverse_iterator it = a.rbegin();
   for ( ; (it != a.rend()) && (*it == '0'); ++it);
   a.erase(it.base(), a.end());
    
   std::cout << a << std::endl;
}
Добавлено через 20 секунд
Так что ли?
1
Заблокирован
18.03.2013, 06:31 7
Учитывает разницу между 15000000. и 15000000.1000000
Что-то типа 125 вообще не трогает

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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
#define buf 50
 
int main()
{   char s1[buf], s2[buf];
    int len1,len2,i;
    int fraction = 0; //есть ли точка (дробная часть)?
    
    printf("s1 = ");
    scanf("%s",s1);
    strcpy(s2,s1);
    len2 = len1 = strlen(s1);
 
    for(i=0;i<len1;i++)
        if(s1[i]=='.')
        {   fraction = 1; //точка есть
            break;
        }
 
    if (fraction) //если точка есть
    {   while(s1[len2-1]=='0' && s1[len2-1]!='.')
            len2--;
        s2[len2]='\0';
    }
 
    printf("s2 = %s",s2);
 
    flushall();getchar();
    return 0;
}
1
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
18.03.2013, 08:46  [ТС] 8
всем спасибо
все работает

Добавлено через 2 часа 3 минуты
Воспользовался этим кодом
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
#include <iostream>
#include <string>
 
 
int main() {
   std::string a = "156,870000000000";
    
   std::string::reverse_iterator it = a.rbegin();
   for ( ; (it != a.rend()) && (*it == '0'); ++it);
   a.erase(it.base(), a.end());
    
   std::cout << a << std::endl;
}
есть одно но, при вводе числа 50000 от него отбрасываются нули и получается 5
хотя число должно быть 50000
подскажите как исправить

сделал так все работает

C++
1
2
3
4
5
6
            if (str.find(',') != string::npos)
            {
             string::reverse_iterator i = str.rbegin();
             for (  ;(i != str.rend()) && (*i == '0'); ++i);
                        str.erase(i.base(), str.end());
            }
0
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 876
Записей в блоге: 10
18.03.2013, 22:53 9
Держите меня семеро:
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
#include <string>
#include <iostream>
#include <regex>
 
using namespace std;
 
int main()
{
    setlocale( LC_ALL, "Russian" );
 
    string empty;
    string demo = "00 мощь 000 ре0гул0ярных выражений000000: ";
    regex regex0( "0" );
    cout << "Вот, в чем " << regex_replace( demo, regex0, empty ) << endl;
 
    // шаблон поиска числа, вся магия тут
    // поиск и trim вне зависимости от границ слов любых чисел, кроме 0
    regex trim_any( "((([1-9]\\d*))(\\.\\d*[1-9])?)|(0\\.\\d*[1-9])" ); 
 
    string mytext =
        "Come on everybody 123\n"\
        "Clap 0.123 your hands. 456.987 \n"\
        "Oh, you're 123.0 looking good!\n"\
        "000321I'm gonna sing my song1230000\n"\
        "It won't take long 0000876000\n"\
        "We gonna do the twist 0.000012313000\n"\
        "And it's goes000123000.000456000like this!";
 
    const sregex_iterator end;
    for ( sregex_iterator i( mytext.begin(), mytext.end(), trim_any ); i != end; ++i )
    {
        cout << i->str() << "\t";
    }
    cin.get();
}
produces
Вот, в чем мощь регулярных выражений:
123
0.123
456.987
123
321
1230000
876000
0.000012313
123000.000456
Кликните здесь для просмотра всего текста


Добавлено через 13 часов 15 минут

Не по теме:

Видимо, не все любят Элвиса...



Добавлено через 16 минут
Я к тому, что регулярные выражения - давно изобретённое и вылизанное транспортное средство, которое много чего умеет и далеко за границами задачи, которая перед Вами, masikus, стоит в данном случае. Причем "ездить путями", для которых предназначены регулярные выражения, при проф. программировании может прийтись часто. Уже шла речь Вытянуть номер телефона. Вообще имхо пора написать FAQ по этой теме, если до сих пор нет.
1
Higher
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
18.03.2013, 23:21 10
Регулярки, конечно, штука мощная - с их помощью можно даже NP-полные задачи решать. Но вот только в этой задаче лучше обойтись без них, так как запутывается код и убивается перформанс.
0
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 876
Записей в блоге: 10
18.03.2013, 23:41 11

Не по теме:

diagon, скажи, почему у тебя "Сообщений: 2,733" - с запятой, а "Репутация: 1741 (1038)" без? :)


Цитата Сообщение от diagon Посмотреть сообщение
NP-полные задачи решать
говоришь. Ну NP-полные задачи вообще можно решать. Что ты имеешь в виду?
0
Higher
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
18.03.2013, 23:57 12
Цитата Сообщение от GoldenId Посмотреть сообщение
2,733
Ну, очевидно, так разделяются тысячи и младшие разряды.

Цитата Сообщение от GoldenId Посмотреть сообщение
Что ты имеешь в виду?
То, что описание регулярными выражениями - NP-полная задача. И, как известно, любую NP-полную задачу можно свести к другой NP-полной задаче. Подробнее можете почитать тут.
1
18.03.2013, 23:57
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.03.2013, 23:57
Помогаю со студенческими работами здесь

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

В матрице из нулей и единиц найти квадрат заданного размера, состоящую целиком из нулей
В матрице A (m, n), которая состоит из нулей и единиц, найти квадрат заданного размера (квадратную...

Определить количество нулей в цифровой записи числа, кроме нулей в младших разрядах
#include &lt;iostream&gt; #include&lt;conio.h&gt; main() { setlocale(LC_ALL, &quot;Russian&quot;); int N,digit = 0;...

Требуется найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц
Здравствуйте, не могу понять в чём может быть ошибка :) Решаю олимпиадную задачу. Но система...


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru