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

Динамический массив и файлы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Ввести строку символов а)вручную, б)из файла и проверить ее на наличие латинских букв http://www.cyberforum.ru/cpp-beginners/thread856995.html
Ни черта не понимаю в работе со строками, прошу помощи у данного форума Нужно: Ввести строку символов а)вручную, б)из файла и проверить ее на наличие латинских букв
C++ Решение уравнений Для уравнений x^3–4x^2+10x–10=0 и x+1–1/x=0 отделить корни уравнений http://www.cyberforum.ru/cpp-beginners/thread856993.html
C++ Задача Таблица. За одно обращение к каждому элементу массива необходимо каждый элемент заменить ближайшим большим следующим за ним
Не могу решить задачу( В массиве А размера n за одно обращение к каждому элементу массива необходимо каждый элемент заменить ближайшим большим следующим за ним. Если такого элемента нет, то необходимо заменить его нулем. Можно использовать дополнительную память.
удалить поддерево C++
Здравствуйте, подскажите, пожалуйста, как можно обойти дерево и посчитать минимальное отношение число листьев/число не листьев, а затем еще и удалить поддерево с этим отношением. Мой код для построения дерева: #include <stdlib.h> #ifndef tree_h #define tree_h static long count_nodes=0; class Tree{ public:
C++ Не считывается файл http://www.cyberforum.ru/cpp-beginners/thread856935.html
Вот решил разобраться с пузырьковой сортировкой. Считываю числа из файла в массив. Вопрос:что сделал не так? Компилятор ошибок не находит, но выбивает: -858993460 -858993460 -858993460 -858993460 -858993460 Ну то есть он явно не может считать цыфры #include <iostream> #include <fstream> using namespace std;
C++ Игра НИМ на С Нужна игра ним на С с базовыми правилами (кто берет последний камень - проигрывает). подробнее

Показать сообщение отдельно
s-partizan
0 / 0 / 0
Регистрация: 09.11.2012
Сообщений: 34
06.05.2013, 01:39  [ТС]     Динамический массив и файлы
Вот она моя сортировка и она работает прекрасно...
C++
1
2
3
4
5
6
7
8
9
10
11
12
 
for(int i=0;i<*n-1;i++)
 for (int k = 0; k < *n - 1; k++)
 {
    if (b[k]>b[k+1])
    {
    temp=b[k];
    b[k]=b[k+1];
    b[k+1]=temp;
    }
 
 }
Но дело то совсем не в ней...
Ошибка будет вылетать уже на этой строке
C++
1
2
3
4
5
 
for(int i=0;i<*n;i++)
 {
     F>>b[i];
 }
А именно где я пытаюсь передать цифры из файла в память (напоминаю, что этих цифер там 1000000000)

Добавлено через 5 минут
Цитата Сообщение от nonedark2008 Посмотреть сообщение
s-partizan, в куче спокойно можно выделить массив в 10^9 элементов, главное чтобы пкамяти хватило.
Не выделяй в начале сразу массив на все элементы. Сначало например посчитай скока элементов в файле лежит, а затем выдели массив с нужным размером и запихай туда числа.
Или сделай динамически расширяемый массив. Т.е. создал массив на 100 элементов и читаешь туда, заполнил весь, тогда выдели массив на 200 элементов, скопируй туда 100 из первого, а первый удали. И т.д. и т.п.

Добавлено через 2 минуты

Так вообще можно завести массив только на 10^4+1 элемент. И с помощью него просто подсчитать, сколько у нас раз встретились 0, 1, 2, ..., 10^4. Короче - обычная упрощенная сортировка подсчетом.
Но мне же не нужно считать сколько там элементов это уже известно их там 10^9.
Мне нужно работать с этой кучей всей сразу...
Может я чего-то не понял...
 
Текущее время: 02:55. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru