Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.69/13: Рейтинг темы: голосов - 13, средняя оценка - 4.69
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548

Доработать пункт меню

01.11.2011, 13:22. Показов 2841. Ответов 39
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
 case 2:{
                  int i, j,size;
                  char nameInput[30]
                  FILE *f1;
                  cout<<"Введите имя файла: ";
                  cin>>nameInput;
                  f1=fopen(nameInput,"r");
                  while (f1 == NULL)//цикл от ошибок,если не сущевствует файла1
                  {
                        cout<<"\tОшибка открытия файла!\n";
                        cout<<"Введите имя файла: ";   //спрашиваешь имя
                        cin>>nameInput;       //считываешь имя
                        f1 = fopen(nameInput,"r");//открытие файла1
                  }
                  fflush(f1);
                  fscanf(f1, "%d", &size);
                  int **matr=new int *[n];
                  for(i=0; i<n; i++)
                        {
                                matr[i]=new int[n]; 
                        }
                  int *masiv=new int[n*n];
                  for (i=0;i<size;i++)
                       {
                       for (j=0;j<size;j++)
                       fscanf (f1,"%d ",&matr[i][j]);
                       }
                        for (i=0;i<=size-1;i++)
                      {
                      for (j=0;j<=size-1;j++)
                      cout << matr[i][j] << " ";
                      cout<<endl;
                      }
                   matrica(matr,n);//функция вывода матрицы на консоль
                    maxsum(matr,n);//функция поиска максимальной среди сумм
                    for(int i = 0; i < n; i++) {
                  delete[] matr[i];}                               
                  delete[] matr;
                 break;}
Помогите доработать,к результате в окне что то не то
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.11.2011, 13:22
Ответы с готовыми решениями:

Добавить пункт в меню
Подскажите пожалуйста. В Visual Studio 2010 создаю проект Win32. Когда просто компилирую выводится окно в котором в меню есть только пункты...

Заменить первый пункт меню на функцию
Не могу заменить первый пункт меню на функцию. // 7.cpp: определяет точку входа для консольного приложения. // #include...

3, 4, 5 пункт меню программы не совсем коретно работает. Хоть убей но ошибку не вижу(
#include&lt;iostream&gt; #include&lt;string&gt; #include&lt;iomanip&gt; #include&lt;fstream&gt; #include &lt;stdlib.h&gt; #include &lt;windows.h&gt; #include...

39
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 12:03  [ТС]
Студворк — интернет-сервис помощи студентам
просто не понял куда твой код вписать,можешь пояснить?
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 12:06

Не по теме:

Но если вам задание поставили обработка исключительных ситуаций, то это уже другое дело. Как звучит задание к данной работе???



Добавлено через 1 минуту
Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
просто не понял куда твой код вписать,можешь пояснить?
- сейчас сделаю - ответь на мой вопрос, мы специально генерируем исключительную ситуацию или же просто нужно ввести так называемую "защиту от дурака"?
0
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 12:10  [ТС]
я вам отписал в пм
0
02.11.2011, 12:12

Не по теме:

Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
я вам отписал в пм
- ок скоро проверю личку, если там всё будет понятно выложу код в топик...;)

1
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 15:30  [ТС]
ответь
0
02.11.2011, 15:47

Не по теме:

Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
ответь
- сейчас уже пишу код, подогодь трошки...;)

0
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 15:51  [ТС]
C++
1
2
3
4
5
6
7
8
9
 case 1:
                  cout<<"Введите порядок матриц:\n";
                  cout<<"n = ";
                  cin>>size;    
                  if(INT_MAX < size){
    cout<<"Value is not integer\n";}
else{       
            size=n;   
                  matr=new int *[n];
я вот твой цикл попробывал,если много ввести то пишет ошибку норм,но если ввести нормальную размерность напрмер 3 бесконечно вводится матрица
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 16:02
Как то так
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
switch(menu)
    {
             case 1:
                 do
                 {
                      cout<<"Ââåäèòå ïîðÿäîê ìàòðèö:\n";
                      cout<<"n = "; 
                      cin>>dn;
                      if(INT_MAX < dn)
                          cout<<"Ââåäåííîå ÷èñëî ïðåâûøàåò ïðåäåë "<<(n = INT_MAX)<<"\n";
                 }
                 while(INT_MAX < dn);
                      
                  n = int(dn);
                  matr=new int *[n];
для INT_MAX подключите #include <limits.h> так на всякий случай, скрин нужной части данного хедера прилагаю
Миниатюры
Доработать пункт меню  
1
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 16:06  [ТС]
а dn следует вначале обьявит тип double или int?

робит норм,но если ввести 9 знаков 1000000000 вылетает))
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 16:10
Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
а dn следует вначале обьявит тип double или int?
- ах ну да я ж верхушку кода не привёл, вот

весь код
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
#include <iostream>
#include <conio.h>
#include <cstdlib>
#include <limits.h>
using namespace std;
 
//Ïðîâåðÿåò ñîäåðæèòñÿ ëè â ôàéëå
//ïîëíàÿ ìàòðèöà, åñëè ºòî òàê âîçâðàò 0
//åñëè íåò âîçâðàò ëþáîå íåíóëåâîå çíà÷åíèå
int isCorrectFile(FILE *f, int &n)
{
        int i, j;
        int buf, k = 0;
        if(!fscanf(f,"%d",&n))
                n = -1;
        else    
        for(i = 0; i < n; i++)
        for(j = 0; j < n; j++)
        {
                //Ìàëî ºëåìåíòîâ
                if(feof(f))
                        break;
                //Íå óäàëîñü ñ÷èòàòü ýëåìåíò
                if(!fscanf(f,"%d",&buf))
                        break;
                k++;//ñ÷¸ò÷èê ÷òåíèé
        }
        fseek(f,0,SEEK_SET);//Âåðíóëè êóðñîð âíà÷àëî ôàéëà
        return n*n - k + 1;
}
 
void maxsum(int **matr, int n)//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
{
    int i,j, max = 0,sum = 0,index,dlina;
    dlina = 1;//äëèíà ñàìîé êîðîòêîé ïîáî÷íîé äèàãîíàëè
    index = n - 1;//íîìåð "ñòàðòîâîãî" (äëÿ ïîäñ÷åòà) ñòîëáöà íóëåâîé ñòðîêè â ïåðâîì öèêëå for() è "ñòàðòîâîé" ñòðîêè äëÿ íóëåâîãî ñòîëáöà âî âòîðîì öèêëå for()
    while(index)
    {
        for(i = 0,j = index; i < dlina; ++i, ++j)//ïåðåìåùàåìñÿ ïðÿìî ïî äèàãîíàëè äî òåõ ïîð, ïîêà íå èñ÷åðïàíà äëèíà äèàãîíàëè dlina
            sum += matr[i][j];
        if (max < sum)//ïðîâåðÿåì çíà÷åíèå sum ñ èìåþùèìñÿ ìàñêèìóìîì
        {
            max = sum;
        }
        sum = 0;
        for(i = 0, j = index; i < dlina; ++i, ++j)//ïåðåìåùàåìñÿ ïðÿìî ïî äèàãîíàëè äî òåõ ïîð, ïîêà íå èñ÷åðïàíà äëèíà äèàãîíàëè dlina
            sum += matr[j][i];
        if (max < sum) //ïðîâåðÿåì çíà÷åíèå sum ñ èìåþùèìñÿ ìàñêèìóìîì
        {
            max = sum;
        }
        sum = 0;
        ++dlina;//óâåëè÷èâàåì ðàçìåð äèàãîíàëè íà 1
        --index;//"ñòàðòîâûé" èíäåêñ index óìåíüøàåì íà 1 è òàê äî òåõ ïîð, ïîêà index íå ðàâåí 0
    }
    cout<<"maximum =  "<<max<<endl<<endl;
    return;
}
 
void matrica(int **matr, int n)//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
{
    int i,j;
    cout<<"\nMatrica A\n\n";
    for (i = 0; i < n; i++)//Âûâîä ðåçóëüòàòà
    {
        for (j = 0; j < n; j++)
        {
            cout << matr[i][j] << " ";
        }
        cout<<endl;
    }
    cout<<endl;
    return;
}
 
int main(int argn, char** argv)
{
    setlocale(LC_ALL,"Rus");//ðóññêèé ÿçûê
    int menu,n,i,j;
    double dn;
    int **matr;
        FILE *f1;
        char nameInput[30];
    cout<<"Âûáåðåòå âàðèàíò ââîäà\n\n";
    cout<<"\t1.Ââîä âðó÷íóþ\n";
    cout<<"\t2.Èç ôàéëà\n\n";
    cout<<"Âàø âàðèàíò: ";
    cin>>menu;    
    switch(menu)
    {
             case 1:
                 do
                 {
                      cout<<"Ââåäèòå ïîðÿäîê ìàòðèö:\n";
                      cout<<"n = "; 
                      cin>>dn;
                      if(INT_MAX < dn)
                          cout<<"Ââåäåííîå ÷èñëî ïðåâûøàåò ïðåäåë "<<(n = INT_MAX)<<"\n";
                 }
                 while(INT_MAX < dn);
                      
                  n = int(dn);
                  matr=new int *[n];
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n]; 
                       for (j=0;j<n ;j++)
                                                          {
                                      cout<<"A["<<i+1<<"]["<<j+1<<"] = " ;
                                      cin>>matr[i][j];
                                                                          }
                  }
                  matrica(matr,n);//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
                  maxsum(matr,n);//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
                  for(i = 0; i < n; i++) {
                  delete[] matr[i];}                               
                  delete[] matr;
                  break;
             case 2:
                  
                  cout<<"Ââåäèòå èìÿ ôàéëà: ";
                  cin>>nameInput;
                  f1=fopen(nameInput,"r");
                  while (f1 == NULL)//öèêë îò îøèáîê,åñëè íå ñóùåâñòâóåò ôàéëà1
                  {
                        cout<<"\tÎøèáêà îòêðûòèÿ ôàéëà!\n";
                        cout<<"Ââåäèòå èìÿ ôàéëà: ";   //ñïðàøèâàåøü èìÿ
                        cin>>nameInput;           //ñ÷èòûâàåøü èìÿ
                        f1 = fopen(nameInput,"r");//îòêðûòèå ôàéëà1
                  }
                  if((i = isCorrectFile(f1, n)) != 0)
                {
                        if(n == -1)
                                printf("Cant read num of elements\n");
                        else
                                printf("Matrix hasn't %d elements\n",i);
                }
                else
                {
                  matr=new int *[n];       
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n];           
                       for (j=0;j<n ;j++)
                            fscanf (f1,"%d ",&matr[i][j]);
                  }
 
                   matrica(matr,n);//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
                    maxsum(matr,n);//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
                    for(int i = n - 1; 0 <= i; i--) {
                          delete[] matr[i];          }                     
                  delete[] matr;
                                }
                 break;
                 default:cout<<"\nÍåòî÷íûé ââîä íîìåðà!";break;
    }    
        getch();
        return 0;
}


Цитата Сообщение от -=ЮрА=- Посмотреть сообщение
int main(int argn, char** argv)
{
* * setlocale(LC_ALL,"Rus");//русский язык
* * int menu,n,i,j;
* * * * double dn;
* * int **matr;
* * * * FILE *f1;
* * * * char nameInput[30];
* * cout<<"Выберете вариант ввода\n\n";
- вон он dn затесался между int menu,n,i,j; и int **matr;

Не по теме:

PS:a.n.o.n.i.m, не забывайте на объявление переменных в лэйблах ругается компилятор.

1
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 16:16  [ТС]
ты попробуй введи 1000000000 (9нулей)
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 16:37
Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
робит норм,но если ввести 9 знаков 1000000000 вылетает))
- сейчас оттестирую...

Добавлено через 6 минут
1000000000
INT_MAX вышел = 2147483647
получается мы переходим цикл и наворачиваемся на выделении памяти, хмммм

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

Не по теме:

a.n.o.n.i.m, скоро отпишусь, надо подумать...

0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 17:19
Откуда берётся исключение не вsяснил и ввёл catch на всё, кроме этого ввёл свою руссификацию это так как бонус, просто setlocale на старье не работает
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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
#include <iostream>
#include <conio.h>
#include <cstdlib>
#include <limits.h>
using namespace std;
 
//Ðóññèôèêàöèÿ
ostream& operator<<(ostream &stream,char* s){
        for(char* ps=s; *ps; ps++){
                if(*ps=='¸')
                        stream<<char(241);
                else if(*ps=='¨')
                        stream<<char(240);
                else if(*ps>=-64 && *ps<=-17)                   
                        stream<<char(*ps+64+128);
                else if(*ps<0)
                        stream<<char(*ps+64+176);
                else
                        stream<<*ps;
        }
        return stream;
}
 
//Ïðîâåðÿåò ñîäåðæèòñÿ ëè â ôàéëå
//ïîëíàÿ ìàòðèöà, åñëè ºòî òàê âîçâðàò 0
//åñëè íåò âîçâðàò ëþáîå íåíóëåâîå çíà÷åíèå
int isCorrectFile(FILE *f, int &n)
{
        int i, j;
        int buf, k = 0;
        if(!fscanf(f,"%d",&n))
                n = -1;
        else    
        for(i = 0; i < n; i++)
        for(j = 0; j < n; j++)
        {
                //Ìàëî ºëåìåíòîâ
                if(feof(f))
                        break;
                //Íå óäàëîñü ñ÷èòàòü ýëåìåíò
                if(!fscanf(f,"%d",&buf))
                        break;
                k++;//ñ÷¸ò÷èê ÷òåíèé
        }
        fseek(f,0,SEEK_SET);//Âåðíóëè êóðñîð âíà÷àëî ôàéëà
        return n*n - k + 1;
}
 
void maxsum(int **matr, int n)//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
{
    int i,j, max = 0,sum = 0,index,dlina;
    dlina = 1;//äëèíà ñàìîé êîðîòêîé ïîáî÷íîé äèàãîíàëè
    index = n - 1;//íîìåð "ñòàðòîâîãî" (äëÿ ïîäñ÷åòà) ñòîëáöà íóëåâîé ñòðîêè â ïåðâîì öèêëå for() è "ñòàðòîâîé" ñòðîêè äëÿ íóëåâîãî ñòîëáöà âî âòîðîì öèêëå for()
    while(index)
    {
        for(i = 0,j = index; i < dlina; ++i, ++j)//ïåðåìåùàåìñÿ ïðÿìî ïî äèàãîíàëè äî òåõ ïîð, ïîêà íå èñ÷åðïàíà äëèíà äèàãîíàëè dlina
            sum += matr[i][j];
        if (max < sum)//ïðîâåðÿåì çíà÷åíèå sum ñ èìåþùèìñÿ ìàñêèìóìîì
        {
            max = sum;
        }
        sum = 0;
        for(i = 0, j = index; i < dlina; ++i, ++j)//ïåðåìåùàåìñÿ ïðÿìî ïî äèàãîíàëè äî òåõ ïîð, ïîêà íå èñ÷åðïàíà äëèíà äèàãîíàëè dlina
            sum += matr[j][i];
        if (max < sum) //ïðîâåðÿåì çíà÷åíèå sum ñ èìåþùèìñÿ ìàñêèìóìîì
        {
            max = sum;
        }
        sum = 0;
        ++dlina;//óâåëè÷èâàåì ðàçìåð äèàãîíàëè íà 1
        --index;//"ñòàðòîâûé" èíäåêñ index óìåíüøàåì íà 1 è òàê äî òåõ ïîð, ïîêà index íå ðàâåí 0
    }
    cout<<"maximum =  "<<max<<endl<<endl;
    return;
}
 
void matrica(int **matr, int n)//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
{
    int i,j;
    cout<<"\nMatrica A\n\n";
    for (i = 0; i < n; i++)//Âûâîä ðåçóëüòàòà
    {
        for (j = 0; j < n; j++)
        {
            cout << matr[i][j] << " ";
        }
        cout<<endl;
    }
    cout<<endl;
    return;
}
 
int main(int argn, char** argv)
{
    //ñì ìîþ ðóññèôèêàöèþ - ýò êàê áîíóñ;)
    //setlocale(LC_ALL,"Rus");//ðóññêèé ÿçûê
    int menu,n = INT_MAX,i,j;
    double dn;
    int **matr;
        FILE *f1;
        char nameInput[30];
    cout<<"Âûáåðåòå âàðèàíò ââîäà\n\n";
    cout<<"\t1.Ââîä âðó÷íóþ\n";
    cout<<"\t2.Èç ôàéëà\n\n";
    cout<<"Âàø âàðèàíò: ";
    cin>>menu;    
    switch(menu)
    {
             case 1:
                 do
                 {
                      cout<<"Ââåäèòå ïîðÿäîê ìàòðèö:\n";
                      cout<<"n = "; 
                      cin>>dn;
                      if((n = INT_MAX) < dn)
                          cout<<"Ââåäåííîå ÷èñëî ïðåâûøàåò ïðåäåë "<<n<<"\n";
                      else
                      {
                          try
                          {
                          if((matr=new int *[(n = int(dn))]) == NULL)
                              cout<<"Îøèáêà âûäåëåíèÿ ïàìÿòè - ââåäèòå ìåíüøåå n\n";
                          }
                          catch(...)
                          {
                              matr = NULL;
                          }
                      }
                 }
                 while(INT_MAX < dn || matr == NULL);
                      
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n]; 
                       for (j=0;j<n ;j++)
                                                          {
                                      cout<<"A["<<i+1<<"]["<<j+1<<"] = " ;
                                      cin>>matr[i][j];
                                                                          }
                  }
                  matrica(matr,n);//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
                  maxsum(matr,n);//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
                  for(i = 0; i < n; i++) {
                  delete[] matr[i];}                               
                  delete[] matr;
                  break;
             case 2:
                  
                  cout<<"Ââåäèòå èìÿ ôàéëà: ";
                  cin>>nameInput;
                  f1=fopen(nameInput,"r");
                  while (f1 == NULL)//öèêë îò îøèáîê,åñëè íå ñóùåâñòâóåò ôàéëà1
                  {
                        cout<<"\tÎøèáêà îòêðûòèÿ ôàéëà!\n";
                        cout<<"Ââåäèòå èìÿ ôàéëà: ";   //ñïðàøèâàåøü èìÿ
                        cin>>nameInput;           //ñ÷èòûâàåøü èìÿ
                        f1 = fopen(nameInput,"r");//îòêðûòèå ôàéëà1
                  }
                  if((i = isCorrectFile(f1, n)) != 0)
                {
                        if(n == -1)
                                printf("Cant read num of elements\n");
                        else
                                printf("Matrix hasn't %d elements\n",i);
                }
                else
                {
                  matr=new int *[n];       
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n];           
                       for (j=0;j<n ;j++)
                            fscanf (f1,"%d ",&matr[i][j]);
                  }
 
                   matrica(matr,n);//ôóíêöèÿ âûâîäà ìàòðèöû íà êîíñîëü
                    maxsum(matr,n);//ôóíêöèÿ ïîèñêà ìàêñèìàëüíîé ñðåäè ñóìì
                    for(int i = n - 1; 0 <= i; i--) {
                          delete[] matr[i];          }                     
                  delete[] matr;
                                }
                 break;
                 default:cout<<"\nÍåòî÷íûé ââîä íîìåðà!";break;
    }    
        getch();
        return 0;
}
Миниатюры
Доработать пункт меню  
1
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
02.11.2011, 18:31  [ТС]
все хорошо,но 1) что надо ввести чтобы чтобы писало Ошибка выделения памяти - введите меньшее у меня всегда пишет Введенное число превышает предел
2)если я руские буквы заменю английским транслитом "vvedite n" например то
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
ostream& operator<<(ostream &stream,char* s){
        for(char* ps=s; *ps; ps++){
                if(*ps=='¸')
                        stream<<char(241);
                else if(*ps=='¨')
                        stream<<char(240);
                else if(*ps>=-64 && *ps<=-17)                   
                        stream<<char(*ps+64+128);
                else if(*ps<0)
                        stream<<char(*ps+64+176);
                else
                        stream<<*ps;
        }
        return stream;
}
можно убрать?тем самым уменьшив код

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

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
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#include <iostream>
#include <conio.h>
#include <cstdlib>
#include <limits.h>
#include <fstream>
using namespace std;
 
//Проверяет содержится ли в файле
//полная матрица, если єто так возврат 0
//если нет возврат любое ненулевое значение
int isCorrectFile(FILE *f, int &n)
{
        int i, j;
        int buf, k = 0;
        if(!fscanf(f,"%d",&n))
                n = -1;
        else    
        for(i = 0; i < n; i++)
        for(j = 0; j < n; j++)
        {
                //Мало єлементов
                if(feof(f))
                        break;
                //Не удалось считать элемент
                if(!fscanf(f,"%d",&buf))
                        break;
                k++;//счётчик чтений
        }
        fseek(f,0,SEEK_SET);//Вернули курсор вначало файла
        return n*n - k ;
}
 
void maxsum(int **matr, int n)//функция поиска максимальной среди сумм
{
    int i,j, max = 0,sum = 0,index,dlina;
    dlina = 1;//длина самой короткой побочной диагонали
    index = n - 1;//номер "стартового" (для подсчета) столбца нулевой строки в первом цикле for() и "стартовой" строки для нулевого столбца во втором цикле for()
    while(index)
    {
        for(i = 0,j = index; i < dlina; ++i, ++j)//перемещаемся прямо по диагонали до тех пор, пока не исчерпана длина диагонали dlina
            sum += matr[i][j];
        if (max < sum)//проверяем значение sum с имеющимся маскимумом
        {
            max = sum;
        }
        sum = 0;
        for(i = 0, j = index; i < dlina; ++i, ++j)//перемещаемся прямо по диагонали до тех пор, пока не исчерпана длина диагонали dlina
            sum += matr[j][i];
        if (max < sum) //проверяем значение sum с имеющимся маскимумом
        {
            max = sum;
        }
        sum = 0;
        ++dlina;//увеличиваем размер диагонали на 1
        --index;//"стартовый" индекс index уменьшаем на 1 и так до тех пор, пока index не равен 0
    }
    cout<<"maximum =  "<<max<<endl<<endl;
    return;
}
 
void matrica(int **matr, int n)//функция вывода матрицы на консоль
{
    int i,j;
    cout<<"\nMatrica A\n\n";
    for (i = 0; i < n; i++)//Вывод результата
    {
        for (j = 0; j < n; j++)
        {
            cout << matr[i][j] << " ";
        }
        cout<<endl;
    }
    cout<<endl;
    return;
}
 
int main(int argn, char** argv)
{
    int menu,n = INT_MAX,i,j;
    double dn;
    int **matr;
    FILE *f1;
    char nameInput[30];
    cout<<"Viberete variant vvoda:\n\n";
    cout<<"\t1.Vvod vruchnuy\n";
    cout<<"\t2.Iz faila\n\n";
    cout<<"Vach variant: ";
    cin>>menu;    
    switch(menu)
    {
             case 1:
                               do
                                 {
                                          cout<<"Vvedite poradok matrici:\n";
                                          cout<<"n = "; 
                                          cin>>dn;
                                          if((n = INT_MAX) < dn)
                                                  cout<<"Vvedennoe chislo previshaet predel "<<n<<"\n";
                                          else
                                          {
                                                  try
                                                  {
                                                  if((matr=new int *[(n = int(dn))]) == NULL)
                                                          cout<<"Oshibka videleniy pamyti - ccedite menche n\n";
                                                  }
                                                  catch(...)
                                                  {
                                                          matr = NULL;
                                                  }
                                          }
                                 }  
                                 while(INT_MAX < dn || matr == NULL);
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n]; 
                       for (j=0;j<n ;j++)
                                                          {
                                      cout<<"A["<<i+1<<"]["<<j+1<<"] = " ;
                                      cin>>matr[i][j];
                                                                          }
                  }
                  matrica(matr,n);//функция вывода матрицы на консоль
                  maxsum(matr,n);//функция поиска максимальной среди сумм
                  for(i = 0; i < n; i++) {
                  delete[] matr[i];}                               
                  delete[] matr;
                  break;
         case 2:               
                  cout<<"Vvedite imy faila: ";
                  cin>>nameInput;
                  f1=fopen(nameInput,"r");
                  while (f1 == NULL)//цикл от ошибок,если не сущевствует файла1
                  {
                        cout<<"\tOshibka otkritiy faila!\n";
                        cout<<"Vvedite imy faila: ";   //спрашиваешь имя
                        cin>>nameInput;           //считываешь имя
                        f1 = fopen(nameInput,"r");//открытие файла1
                  }
                  if((i = isCorrectFile(f1, n)) != 0)
                {
                        if(n == -1)
                                printf("Cant read num of elements\n");
                        else
                                printf("U matrix net %d elements\n",i);
                }
                else
                {
                  matr=new int *[n];       
                  for (i=0;i<n ;i++)
                  {
                       matr[i]=new int[n];           
                       for (j=0;j<n ;j++)
                            fscanf (f1,"%d ",&matr[i][j]);
                  }
 
                   matrica(matr,n);//функция вывода матрицы на консоль
                    maxsum(matr,n);//функция поиска максимальной среди сумм
                    for(int i = n - 1; 0 <= i; i--) {
                          delete[] matr[i];          }                     
                  delete[] matr;
                                }
                 break;
                 default:cout<<"\nNetochniy vvod nomera!";break;
    }    
        getch();
}
Вот в общем полный код что получилось
Нужно сделать если ввдена матрица неверно то программа просто завершалась.Ду вайл убераю вылетает. не просило еще раз ввести.Ну и ранее пост там вопрос еще

Добавлено через 28 минут
ответь в пм по вопросу который отписал
0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
02.11.2011, 18:34
Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
можно убрать?тем самым уменьшив код
- легко, я просто как вариант руссификации предложил, впринципе оставил

Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
Ду вайл убераю вылетает. не просило еще раз ввести.
- ну скрин я не рисовал, и у меня отрабатывало (хотя я в Debug тестил), а компилятор какой использован???
0
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
03.11.2011, 08:45  [ТС]
вам в пм все отписал,если есть еще какие вопросы отпишите
0
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
04.11.2011, 11:19  [ТС]
-=ЮрА=- почисти почту свою ,чтоб можно было отправить письмо
0
04.11.2011, 11:54

Не по теме:

Цитата Сообщение от a.n.o.n.i.m Посмотреть сообщение
-=ЮрА=- почисти почту свою ,чтоб можно было отправить письмо
- уже почистил, пиши

0
Автор FAQ
 Аватар для -=ЮрА=-
6614 / 4256 / 401
Регистрация: 08.08.2009
Сообщений: 10,325
Записей в блоге: 24
04.11.2011, 21:40
a.n.o.n.i.m, вообщем вот проект на плюсах, который автоматичиски либо читает матрицу из файла, либо предлагает ручной ввод в зависимости от того передан ли в командной строке путь к файлу или нет. В алгоритме предусмотрены сообщения при неполном объёме данных в файле, либо при вводе слишком большого n вручню. Если чтение из файла либо ручной ввод успешны на экране светится матрица. Я выкладываю экзешник и скрины работы если всё устраивает связывайся со мной по поводу пароля на исходники...
Миниатюры
Доработать пункт меню   Доработать пункт меню   Доработать пункт меню  

Вложения
Тип файла: rar task4anonim.proj.rar (2.3 Кб, 7 просмотров)
Тип файла: rar task4anonim.exe.rar (67.9 Кб, 6 просмотров)
0
139 / 139 / 39
Регистрация: 26.02.2011
Сообщений: 548
05.11.2011, 10:29  [ТС]
проверьте лс или вконтак я отписал о том что нужно доделать и лучще бы вы зашли в icq бы так было бы
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.11.2011, 10:29
Помогаю со студенческими работами здесь

Надо чтоб при нажатии на свой пункт меню открывался новый док.
Значит в MDI проекте, добовляю я свой пункт меню, и надо чтоб при нажатии на него открывался новый док, тоже что и File-&gt;New....

Нужно чтобы когда в меню выбираешь какой-нибудь пункт выдавало нужную информацию
(ЭТО НУЖНО ПОМЕСТИТЬ В ПРОГРАММУ) Марка: LADA, Модель: Kalina, универсал, номер: Р654НО Марка: Volkswagen, Модель: Polo, седан,...

В меню tools добавить пункт меню выбор которого запустит интегрированную в ОС windows программу MSPaint.exe
В Borland c++ в меню tools добавить пункт меню выбор которого запустит интегрированную в ОС windows программу MSPaint.exe

Клик на пункт меню
Создаю меню: HMENU hmenu1; HMENU hPopMenuFile; hmenu1 = CreateMenu(); hPopMenuFile = CreatePopupMenu(); AppendMenu(hmenu1,...

Курсор не отлавливает пункт меню
После запуска программы при переходе в меню по ссылке &quot;Список дисков&quot; выдает окно с дисками, по нажатии на один из пунктов должно...


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

Или воспользуйтесь поиском по форуму:
40
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru