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

Внешний интерфейс - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Собрать проект Seman под Windows 7 http://www.cyberforum.ru/cpp-beginners/thread612400.html
Доброго времени всем! Эксперты, помогите пожалуйста собрать проект Seman (http://sourceforge.net/scm/?type=svn&group_id=242864) под windows 7 или очертить главные шаги? Занимаюсь компьютерной лингвистикой и хочу проверить фозможности проекта в научных целях. Я сам не я C/C++ прграммист и от того пршу вашей помощи (сам конечно налегаю на доки). На данный момент скачал Bison установил,...
C++ Поиск в map и friend функция Есть класс Phone, унаследованный от ATC и TelephoneService, в классе Phone необходимо сделать функцию, которая позволяет вывести по номеру телефона название города, насколько я понимаю необходимо сделать map массив, в который будут заносится ключ(idCity) и значение(nameCity),а затем будет выполнятся поиск по ключу, который берется из 5-ти первых цифр номера абонента (numberSubscriber), также... http://www.cyberforum.ru/cpp-beginners/thread612399.html
C++ оператор for c++
вывести все целые числа из диапазона от А до В (А<=B), оканчивающиеся на X или Y условие понятно какое но выводит все числа из диапазона, условие не затрагивается никак, не могу понять что исправить вот код #include<iostream.h> int main() { int a,b,x,y; cout<<"vvod a b"<<endl; cin>>a>>b; cout<<"vvod x y"<<endl; cin>>x>>y; if (a%10==x || b%10==y) for(int i=a; i<=b; i++)
C++ Про if
double value1=0; double value2=0; double value3=0; cout<<"enter tree integer: "; cin>>value1>>value2>>value3; if (value1>=value2>=value3) cout<<"sorted sequence: "<<value1<<" "<<value2<<" "<<value3<<endl;
C++ Сохранить в новом файле те названия, которые встречаются в двух исходных http://www.cyberforum.ru/cpp-beginners/thread612370.html
Помогите пожалуйста решить задачку! Программа должна прочитать данные из двух указанных текстовых файлов, содержащих записи с названиями товаров(считать что число записей в файлах может быть различно, но не более 20). Данные нужно предварительно загрузить в два строковых массива, проанализировать и сохранить в новом файле те названия, которые встречаются в обоих массивах. Заранее спасибо! ...
C++ Оформить каждый пункт задания в виде функции программа определяет максимум среди сумм диагоналей, параллельных главной диагонали матрицы. Нужно оформить каждый пункт задания в виде функции; все необходимые переменные передаются им в качестве параметров #include "iostream.h" #include "conio.h" int main() { int a; int i, j, n=10, m=10, sum=0, max=0, b=n-1, c=1; int *p;//указатель p=new int; подробнее

Показать сообщение отдельно
alsav22
5284 / 4803 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
24.06.2012, 19:55     Внешний интерфейс
Чтение из файла лучше так сделать:

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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include <iostream>
#include <iomanip>
#include <conio.h>
#include <cstdio>
using namespace std;
 
FILE *F1, *F2;
 
void main()
{
    setlocale(0, "");
    system("cls");
    if ((F1 = fopen("C:\\Temp\\1.txt","r")) == NULL)
    {
        cout << "Невозможно открыть файл." << endl;
        system("pause");
        exit(1);
    }
    const int BUFF = 1000; // Задаётся размер буфера для чтения из файла.
    int *buff = new int[BUFF]; // Выделяется память для буфера.
    int n = 0; // Количество считываний чисел из файла. 
    
    while (n < BUFF) // Будет считывать в буфер из файла до конца файла
                                  // или пока количество считываний не станет
                                  // равным размеру буфера.
    {
       fscanf(F1, "%d", &buff[n]);
       if (feof(F1)) break;
       n++;
    }
    
    fclose(F1);
    
    int *p = new int[n]; // Выделяем память под массив из n 
                         // считанных чисел.
    copy(buff, buff + n, p); // Копируем считанные числа из буфера в массив.
    
    delete [] buff; // Освобожаем память занятую буфером.
    
    int ch = 0, nech = 0;
    for (int i = 0; i < n; i++)
    {
        if (*(p+i)%2)                
        {
            nech++;                
        }
        if (!(*(p + i)%2) && p[i]!=0)  
        {
            ch++;                  
        }
    }
 
    int *p1=new int[nech];      
    int *p2=new int[ch];       
    ch = 0; nech = 0;
 
    for (int i = 0; i < n; i++)
    {
        if (*(p + i)%2)             
        {
            *(p1 + nech)=*(p + i);
            nech++;              
        }
        if (!(*(p+i)%2) && *(p+i)!=0)        
        {
            *(p2+ch)=*(p+i);
            ch++;              
        }
 
    } 
    
    if ((F2=fopen("C:\\Temp\\2.txt","w")) == NULL)
    {
        cout << "Невозможно открыть файл." << endl;
        system("pause");
        exit(1);
    }
    
    fprintf(F2, "%s%d%s", "Все (", n, ") :  ");
    for(int i = 0; i < n; i++)
    fprintf(F2, "%d  ", p[i]);              
    
    fprintf(F2, "%s%d%s", "\nНечётные (", nech, ") :  ");
    for(int i = 0; i < nech; i++)
    fprintf(F2, "%d  ", p1[i]);
    
    fprintf(F2, "%s%d%s", "\nЧётные (", ch, ") :  ");
    for(int i = 0; i < ch; i++)
    fprintf(F2, "%d  ", p2[i]);
    
    fclose(F2);
    
    system("pause");
    delete p; delete p1; delete p2;
}
Теперь в файле 1.txt может быть сколько угодно чисел. Будет считанно всё, но не больше, чем задано в BUFF.
 
Текущее время: 22:39. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru