Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.51/43: Рейтинг темы: голосов - 43, средняя оценка - 4.51
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37

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

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

Студворк — интернет-сервис помощи студентам
как сделать чтобы программа отбрасывала незначащие нули после запятой в строке (string)
Например вводим строку a = 156,870000000000
а на выводе получаем а = 156,87
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.03.2013, 05:10
Ответы с готовыми решениями:

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

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

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

11
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
18.03.2013, 05:38
Пока Синтаксис строки форматирования
1
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
18.03.2013, 05:53  [ТС]
немножко не так написал
нужно отбросить нули для дальнейших операций со строкой.(подсчет размера,поиск элемента,ограничение количества вводимых символов)
например мне нужно ввести число состоящее из шести значащих цифр.
Если ограничить вводимый диапазон до шести знаков и ввести 63,22000000 ,то будет ошибка, а нужно чтобы было правильно. Вот и задача отбросить эти нули
0
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
18.03.2013, 06:09
Как-то так:
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
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
18.03.2013, 06:13
Не совсем понял. 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!
 Аватар для gray_fox
1610 / 1302 / 180
Регистрация: 21.04.2012
Сообщений: 2,733
18.03.2013, 06:25
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
 Аватар для IrineK
2023 / 1641 / 425
Регистрация: 23.02.2011
Сообщений: 6,002
Записей в блоге: 25
18.03.2013, 06:31
Учитывает разницу между 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  [ТС]
всем спасибо
все работает

Добавлено через 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
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
18.03.2013, 22:53
Держите меня семеро:
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
 Аватар для diagon
1953 / 1219 / 120
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
18.03.2013, 23:21
Регулярки, конечно, штука мощная - с их помощью можно даже NP-полные задачи решать. Но вот только в этой задаче лучше обойтись без них, так как запутывается код и убивается перформанс.
0
 Аватар для GoldenId
142 / 143 / 64
Регистрация: 11.11.2010
Сообщений: 877
Записей в блоге: 10
18.03.2013, 23:41

Не по теме:

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


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

Цитата Сообщение от GoldenId Посмотреть сообщение
Что ты имеешь в виду?
То, что описание регулярными выражениями - NP-полная задача. И, как известно, любую NP-полную задачу можно свести к другой NP-полной задаче. Подробнее можете почитать тут.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.03.2013, 23:57
Помогаю со студенческими работами здесь

Найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц
Нужно найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц. В чем ошибка ? #include &lt;iostream&gt; ...

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru