Форум программистов, компьютерный форум CyberForum.ru

Как найти максимум который выходить за предел всех типов данных? - C++

Восстановить пароль Регистрация
 
Vitiok
4 / 4 / 1
Регистрация: 17.01.2012
Сообщений: 70
13.03.2012, 19:53     Как найти максимум который выходить за предел всех типов данных? #1
Я делал таким образом, но числа ограничены int. Как можна найти минимум и максимум если число будет например 999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999999
заранее благодарю.

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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
// Макс мин.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <conio.h>
 
using namespace std;
 
int _tmain(int argc, _TCHAR* argv[])
{
    setlocale(0, "");
 
    int a, b;
 
    ifstream in_stream("in.txt", ios::in);
    if(!in_stream)
    {
        cout<<"Input error!"<<endl;
        return 1;
    }
 
    int n = 3;
 
    cout<<"Числа:"<<' ';
 
    int *mass = new int[n];
    for(int i = 0; i<n; i++)
        in_stream>>mass[i];
    in_stream.close();
 
    for(int i=0; i<n; i++)
    {
        cout<<mass[i]<<" ";
    }
 
    a=b=0;
    for(int i=0; i<n; i++)
    {
        if(mass[i]<mass[a])
            a=i;
        if(mass[i]>mass[b])
            b=i;
    }
 
    ofstream out_stream("out.txt");
        if(!out_stream)
        {
            cout<<"Input error!";
            return 1;
        }
 
        out_stream<<"Максимум:"<<mass[b]<<endl;
        out_stream<<"Минимум:"<<mass[a]<<endl;
        out_stream.close();
 
    _getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.03.2012, 19:53     Как найти максимум который выходить за предел всех типов данных?
Посмотрите здесь:

найти максимум из x[1]...x[n] C++
Найти максимум, который встречается более одного раза. C++
Найти максимум функции C++
C++ Найти предельные значения для целочисленных типов. Не использовать заранее определенные константы границ типов.
C++ Можно ли на С++ как-то свернуть стек для выхода из рекурсии, а не последовательно выходить из нее?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
13.03.2012, 19:55     Как найти максимум который выходить за предел всех типов данных? #2
Длинная арифметика.
alex_x_x
бжни
 Аватар для alex_x_x
2441 / 1646 / 84
Регистрация: 14.05.2009
Сообщений: 7,163
13.03.2012, 20:01     Как найти максимум который выходить за предел всех типов данных? #3
Vitiok, максимальный-минимальные пределы значений определены в limits.h/climit
если ты про то, что пользователь ввел с консоли слишком большое число, то это отразится во флагах самого потока

C++
1
2
3
4
5
6
7
8
9
10
11
#include <iostream>
 
int main()
{
   int i;
   if (!(std::cin >> i)) {
      std::cout << "bad value" << std::endl;
   } else {
      std::cout << "ok" << std::endl;
   }
}
для большого числа std::istream вернет ошибку
x1Mike7x
 Аватар для x1Mike7x
214 / 127 / 6
Регистрация: 06.11.2010
Сообщений: 234
13.03.2012, 20:21     Как найти максимум который выходить за предел всех типов данных? #4
Для длинных положительных ( да и негативных тоже, но только с обработкой минуса в начале ) чисел можно юзать стринги.
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
#include <iostream>
#include <string>
 
int main()
{
    std::string a, b;
    std::cin >> a >> b;
    if ( a.size() < b.size() || a.size() == b.size() && a < b )
        std::cout << "a < b" << std::endl;
    else if ( a == b )
        std::cout << "a = b" << std::endl;
    else
        std::cout << "a > b" << std::endl;
}
Yandex
Объявления
13.03.2012, 20:21     Как найти максимум который выходить за предел всех типов данных?
Ответ Создать тему
Опции темы

Текущее время: 18:11. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru