Форум программистов, компьютерный форум 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
5416 / 4812 / 442
Регистрация: 04.06.2011
Сообщений: 13,587
24.06.2012, 06:27     Внешний интерфейс
Цитата Сообщение от DU Посмотреть сообщение
там оно вводом пользователя задается.
Если вы в с++ пришли надолго, то освойте дебагер. с ним такие да и не только такие ошибки быстро находятся.
Он сейчас не этот код делает, который вверху страницы, а тот, который на второй странице (17 пост) Внешний интерфейс. Этот-то у него работает.

Добавлено через 12 минут
flock, открытие файла нужно проверять. Сделай в начале такую конструкцию:
C++
1
2
3
4
5
6
if ((F1=fopen("C:\temp\1.txt","r")) == NULL)
    {
        cout << "Невозможно открыть файл." << endl;
        system("pause");
        exit(1);
    }
Хотя бы убедишься, что у тебя файл открывается. У меня, если так прописать путь, файл не открывается. Нужно так: "C:\\temp\\1.txt", тогда открывается, но там и дальше есть ошибки.

Добавлено через 3 часа 41 минуту
while(!feof(F1)||i<n)
{
fscanf(F1,"%d",p[i]);
i++;
}
Это неправильно. Нужно так:
while (!feof(F1) && i < n)
{
fscanf(F1, "%d", &p[i]);
i++;
}

Это не понятно зачем:
if(i-n!=1)
n=i+1;
Убери.

Приблизительно так:

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
#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);
    }
    
    int n = 10, ch, nech;
    int *p = new int[n];
    int i = 0;
    
    while (!feof(F1) && i < n)
    {
       fscanf(F1, "%d", &p[i]);
       i++;
    }
    fclose(F1);
 //if(i-n != 1)
    //n=i+1;
    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", "Все:  ");
    for(int i = 0; i < n; i++)
       fprintf(F2, "%d  ", p[i]);              
    
    fprintf(F2, "%s", "\nНечётные:  ");
    for(int i = 0; i < nech; i++)
       fprintf(F2, "%d  ", p1[i]);
    
    fprintf(F2, "%s", "\nЧётные:  ");
    for(int i = 0; i < ch; i++)
       fprintf(F2, "%d  ", p2[i]);
    
    fclose(F2);
    
    system("pause");
    delete(p); delete(p1); delete(p2);
}
В файле 1.txt десять чисел, разделённых пробелами.
Со scanf() и printf() я плохо знаком, поэтому, наверное, запись в txt.2 можно и лучше как-то сделать. Это сам додумай или посоветует кто.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru