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

Найти косяк - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Выяснить, будет ли последовательность действительных чисел возрастающей http://www.cyberforum.ru/cpp-beginners/thread316243.html
Дана последовательность действительных чисел A1, A2,...,An. Выяснить, будет ли она возрастающей
C++ Даны действительные числа X и Y... Даны действительные числа X и Y, не равные друг другу. Меньшее из этих двух чисел заменить половиной их суммы, а большее- их удвоенным произведением. http://www.cyberforum.ru/cpp-beginners/thread316234.html
C++ Значения True или False
Состаить линейную программу, выводящую значение True, если указанное высказывание является истинным, и False- в противном случае: Квадрат заданного трехзначного числа равен кубу суммы цифр этого числа.
C++ выбрать самое большое значение
как можно узнать в массиве из 5 чисел самое большое значение с помощью цикла
C++ Вывести начальные индексы всех непрерывных последовательностей http://www.cyberforum.ru/cpp-beginners/thread316204.html
(С)Вывести начальные индексы всех непрерывных последовательностей чисел с неувеличивающимися значениями диапазон значений -50 - 50 Добавлено через 22 часа 2 минуты помогите пожалуйста а то сам не справлюсь Добавлено через 12 часов 23 минуты неужели никто не поможет :sorry:
C++ решить програму 1.Заменить в слове все гласные о на а, а буквы а – на о 2.Составить программу для вычеркивания из слова X каждой третьей буквы подробнее

Показать сообщение отдельно
Vlad2410
0 / 0 / 0
Регистрация: 21.10.2010
Сообщений: 15
08.06.2011, 22:22     Найти косяк
Вхождение оператора А линейной программы назовем избыточным, если среди предшествующих ему имеется еще одно вхождение этого оператора, причем левые части всех операторов, находящихся между двумя этими вхождениями, а также левая часть самого оператора А не встречаются в правой части оператора А. Например, второе вхождение оператора х:= у + z в линейной программе "x:=y+z; и:=и-z; x:=y+z" избыточно. В заданной линейной программе удалить все избыточные вхождения операторов.

Помогите найти косяк
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
96
97
98
99
#include "stdafx.h"
#include <iostream>
#include <fstream>
#include <cstdlib>
#include <conio.h>
#include <string.h>
 
using namespace std;
typedef struct oper{
    
    char    opleft;
    char    ravn;
    char    opright1;
    char    zn;
    char    opright2;
    
};
 
void pause() {
    cout<<"Для продолжения нажмите любую клавишу"<<endl;
    getch();
}
 
void vvod(istream &cin, oper *m, int &n) {
     cin>>n;
    
     cin.ignore(100,'\n');
     for(int i=0; i<n; i++){
        
  
        cin>>m[i].opleft;
        cin>>m[i].ravn;
        cin>>m[i].opright1;
        cin>>m[i].zn;
        cin>>m[i].opright2;
 
        
     }
}
 
void vyvod(ostream &out, oper *m, int  n){
    for(int i=0; i<n; i++) {
            out<<m[i].opleft<<m[i].ravn<<m[i].opright1<<m[i].zn<<m[i].opright2<<"\n";
    }
    pause();
}
 
int del(oper *m, int &n, int numberToDelete) {
    for (int i=0;i<n;i++) {
        if (m[i].opleft == numberToDelete) {
            for (int j=i;j<n-1;j++) {
                m[j]=m[j+1];
            }
            n--;
            return 0; 
        }
    }
    return -1;
}
 
int main()
{
    bool dataIn;
setlocale(LC_ALL,"russian");
    oper m[100];
    char Number;
    int N = 3;
    ifstream fileIn;
                    fileIn.open("input1.txt",ios::in);
                    if (fileIn)
                    {
                        vvod(fileIn, m, N); 
                        dataIn = true;
                    }
 
                        for(int i=0;i<N;i++)
                        {
                            for(int j=i+1;j<N;j++)
                            {
                                if(m[i].opleft==m[j].opleft)
                                {
                                    for(int k=i;k>N;k++)
                                    {
                                        if((m[k].opleft==m[i].opright1)&&(m[k].opleft==m[i].opright2))
                                        {
                                            Number=m[i].opleft ;
                                            del(m, N, Number);
                                        }
                                    }
                                }
                            }
                        }
 
                                
                    if (dataIn) 
                    {
                        vyvod(cout, m, N);
                    }
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru