Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 20, средняя оценка - 4.90
masikus
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
#1

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

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

как сделать чтобы программа отбрасывала незначащие нули после запятой в строке (string)
Например вводим строку a = 156,870000000000
а на выводе получаем а = 156,87
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
18.03.2013, 05:10
Я подобрал для вас темы с готовыми решениями и ответами на вопрос Отбрасывание незначащих нулей (C++):

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

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

найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц - C++
Нужно найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц. В чем ошибка ? #include <iostream> #include...

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

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

Требуется найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц - C++
Требуется найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц. Входные данные: В единственной строке...

11
GoldenId
89 / 129 / 32
Регистрация: 11.11.2010
Сообщений: 770
Записей в блоге: 14
Завершенные тесты: 1
18.03.2013, 05:38 #2
Пока Синтаксис строки форматирования
1
masikus
2 / 2 / 0
Регистрация: 03.03.2013
Сообщений: 37
18.03.2013, 05:53  [ТС] #3
немножко не так написал
нужно отбросить нули для дальнейших операций со строкой.(подсчет размера,поиск элемента,ограничение количества вводимых символов)
например мне нужно ввести число состоящее из шести значащих цифр.
Если ограничить вводимый диапазон до шести знаков и ввести 63,22000000 ,то будет ошибка, а нужно чтобы было правильно. Вот и задача отбросить эти нули
0
IrineK
Заблокирован
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
GoldenId
89 / 129 / 32
Регистрация: 11.11.2010
Сообщений: 770
Записей в блоге: 14
Завершенные тесты: 1
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
gray_fox
What a waste!
1551 / 1256 / 74
Регистрация: 21.04.2012
Сообщений: 2,634
Завершенные тесты: 3
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
IrineK
Заблокирован
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
masikus
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
GoldenId
89 / 129 / 32
Регистрация: 11.11.2010
Сообщений: 770
Записей в блоге: 14
Завершенные тесты: 1
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
diagon
Higher
1936 / 1202 / 49
Регистрация: 02.05.2010
Сообщений: 2,925
Записей в блоге: 2
18.03.2013, 23:21 #10
Регулярки, конечно, штука мощная - с их помощью можно даже NP-полные задачи решать. Но вот только в этой задаче лучше обойтись без них, так как запутывается код и убивается перформанс.
0
GoldenId
89 / 129 / 32
Регистрация: 11.11.2010
Сообщений: 770
Записей в блоге: 14
Завершенные тесты: 1
18.03.2013, 23:41 #11

Не по теме:

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


Цитата Сообщение от diagon Посмотреть сообщение
NP-полные задачи решать
говоришь. Ну NP-полные задачи вообще можно решать. Что ты имеешь в виду?
0
diagon
Higher
1936 / 1202 / 49
Регистрация: 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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.03.2013, 23:57
Привет! Вот еще темы с ответами:

Определить количество нулей в цифровой записи числа, кроме нулей в младших разрядах - C++
Дано натуральное число N (N &gt; 9). Определить количество нулей в цифровой записи числа, кроме нулей в младших разрядах. Пример. N = 10 025...

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

Определить количество нулей в цифровой записи числа, кроме нулей в младших разрядах (Pascal -> С++) - C++
Var i: longint; N: integer; begin write('input Nomber, pleeeaaase: '); readln(i); N:= 0; while ((i mod 10) = 0) do ...

String char айти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц - C++
Требуется найти самую длинную непрерывную цепочку нулей в последовательности нулей и единиц При этом в файл всегда сохраняется &quot;1&quot;....


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru