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

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

Войти
Регистрация
Восстановить пароль
 
grain
0 / 0 / 0
Регистрация: 03.07.2012
Сообщений: 56
#1

поиск элемента в массиве из файла - C++

03.07.2012, 11:33. Просмотров 434. Ответов 1
Метки нет (Все метки)

Здравствуйте!
Такая задача (с++): нужно вывести на экран элемент, находящийся в файле, в котором записан столбец с названием угла и множество значений при различных отсчетах по дальности. Выглядит содержание файла примерно так:

"0: 0 0 0 2 567 0 4 56 897...
1: 0 0 98 235 214 2 3 0 0 234...
......" (0, 1..., стоящие перед двоеточием - углы)
вывести на экран из подобного файла нужно любое из значений, стоящих после двоеточия по заданным координатам.

Проблема в том, что объем файл большеват (около 15 мб): углов - 2048, повторяющихся 3 раза (т.е., в общем 6144 ряда углов) и значений при каждом по 1200...
ошибок нет, но прочтение всего файла не получается...


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
#include<iostream>
#include <stdio.h>
#include <conio.h>
#include<string>
using namespace std;
 
struct file
{
    string angle;
    int a[1200];           //массив значений
};
 
void main ()
{
    struct file f[6144];
    long int i, j;
    long int a[1200];
    string angle;
    string N;
    long int M;
    cout<<"vvedite ugol:"<<endl;
    cin>>N;                                                    //ряд
    cout<<"vvedite chislo po dal'nosti"<<endl;
    cin>>M;                                                      //столбец
    freopen ("file.txt", "r", stdin);
 
           //чтение содержимого файла:
    for (i=0; i<6144; i++)
    {
        
        {
            cin>>angle;
            f[i].angle=angle;
            for (j=0; j<1200; j++)
            {
                cin>>a[j];
                f[i].a[j]=a[j];
            }
        }
    }
 
           //вывод:
    for (i=0; i<6144; i++)
    {
        if (f[i].angle==N)
        {
            cout<<f[i].a[M]<<endl;
        }
    }
}
Спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.07.2012, 11:33
Здравствуйте! Я подобрал для вас темы с ответами на вопрос поиск элемента в массиве из файла (C++):

Поиск элемента в массиве - C++
Как написать рекурсивную функцию для поиска элемента в массиве?

Поиск элемента в массиве - C++
Здравствуйте! Помогите доделать программу, нужно чтобы программа в пункте 2 (L==2)искала в массиве определенную константу (любое значение...

Поиск элемента в массиве - C++
Почему не выводится цифра 6? #include &lt;stdio.h&gt; #include &lt;string.h&gt; int main () { char szInput = &quot;1234567890&quot;; int k, n...

поиск элемента в линейном массиве - C++
буду благодарен вашей помощи=( Поиск элемента в линейном массиве .

поиск определенного элемента в массиве - C++
Задан массив, который состоит из n элементов. Найти элемент для которого сумма элементов, что стоят до него, меньше всего отличается от...

Бинарный поиск элемента в массиве - C++
Суть - программа ищет число по формуле K=(a+b)/2 бинарным поиском, и выводит его порядковый номер (индекс) в отсортированом массиве....

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
asidorchenko
379 / 205 / 25
Регистрация: 09.04.2012
Сообщений: 635
03.07.2012, 12:21 #2
Памяти под такой массив структур не хватило. У меня программа тупо вылетает.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
#include<iostream>
#include <stdio.h>
#include<string>
using namespace std;
 
struct file1
{
    string angle;
    int a[1200];           //массив значений
};
 
void main ()
{
 
    struct file1 f;
 
// Размер одной структуры
    printf("%d\n", sizeof(file1));
 
// А если структур 6144
    printf("%d\n", sizeof(file1)*6144);
 
}
Может нужно выделять память только под один элемент массива
C++
1
2
3
4
struct file1* f;
f=new file1();  
...
delete f;
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
03.07.2012, 12:21
Привет! Вот еще темы с ответами:

Поиск минимального элемента в массиве - C++
Помогите решить задачку,Вводим в ручную массив и в нем нужно найти минимальные элемент Заранее спасибо

Поиск элемента в одномерном массиве. - C++
задан целочисленный одномерный массив. найти минимальный элемент этого массива и поставить его в начало.

Поиск в массиве минимального элемента - C++
Ребят помогите. дан массив n*n. нужно найти в каждом столбце минимальный элемент и записать данные в новый массив. подтолкните на путь...

Поиск элемента в одномерном массиве - C++
Помогите, пожалуйста, с решением задач: 1)Найти среднее арифметическое всех отрицательных элементов одномерного вещественного массива...


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

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

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