Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
4 / 4 / 3
Регистрация: 05.09.2011
Сообщений: 113

Подкорректируйте код

14.12.2011, 22:15. Показов 610. Ответов 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
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
#include <iostream.h>
#include <conio.h>
#include <iomanip.h>
#include <windows.h>
int rus(char str_c[])
{char *str=new char[255];
AnsiToOem(str_c,str);
cout<<'\n'<<str;
return(0);
}
 
int main()
{
int nstr,nstb,k,i,j;
rus("Введите количество строк и столбцов через пробел   ");
cin>>nstr>>nstb;
int **p=new int *[nstr];
for(i=0;i<nstr;i++)
p[i]=new int [nstb];
 for(i=0;i<nstr;i++)
  for(j=0;j<nstb;j++)
 {
   cout<<"  mas ["<<i<<"] "<<"["<<j<<"] = "; cin>>p[i][j];
 }
 for(i=0;i<nstr;i++)
 {
   cout<<endl<<endl;
   for(j=0;j<nstb;j++)
   cout<<setw(3)<<p[i][j]<<" ";
 }
 k=0;
for(i=0;i<nstr;i++)
{
for(j=0;j<nstb;j++)
{
 if(p[i][j] == 0) k++;
}
 if(k == nstb-1){
 for(j=0;j<nstb;j++){
  p[i][j]=p[i+1][j];
  }
 }
 k=0;
}
cout<<endl;
 for(i=0;i<nstr;i++)
 {
   cout<<endl<<endl;
   for(j=0;j<nstb;j++)
   cout<<setw(3)<<p[i][j]<<" ";
 }
getch();
return 0;
}
Добавлено через 1 час 16 минут
Я смотрю, ответов нету, просто интересно, это реально сложная задача?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
14.12.2011, 22:15
Ответы с готовыми решениями:

Пожалуйста подкорректируйте программу!
Помогите пожалуйста подкорректировать программу! Суть в том , что программа работает , но при вводе отрицательных , дробных , и других...

Подкорректируйте пожалуйста код.
Поместить в массив все числа в записи которых есть двойка, а рядом в массив записать, что получится из этого числа без двоекэ...

Подкорректируйте\исправьте код пожалуйста
Записать в одномерный массив, те числа из числовой последовательности введенной пользователем, у которых, сумма цифр стоящих на четных...

2
4 / 4 / 3
Регистрация: 05.09.2011
Сообщений: 113
15.12.2011, 00:31  [ТС]
Все работает, но числа уменьшаются на 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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#include <iostream.h>
#include <conio.h>
#include <iomanip.h>
#include <windows.h>
#include <stdlib.h>
void numberofstr(int **p, int nstr, int nstb);
void str(int **p, int &nstr, int nstb);
void st(int **p, int nstr, int &nstb);
void vvod(int **p, int nstr, int nstb);
void outputt(int **p, int nstr, int nstb);
int rus(char str_c[])
{char *str=new char[255];
AnsiToOem(str_c,str);
cout<<'\n'<<str;
return(0);
}
int main()
{
int nstr,nstb,k,i,j;
rus("Введите количество строк и столбцов через пробел   ");
cin>>nstr>>nstb;
int **p=new int *[nstr];
for(i=0;i<nstr;i++)
p[i]=new int [nstb];
vvod(p,nstr,nstb);
rus("Исходный массив => "); cout<<endl;
outputt(p,nstr,nstb);
str(p,nstr,nstb);
st(p,nstr,nstb);
rus("Уплотненная матрица без нулей в строках и столбцах => "); cout<<endl;
outputt(p,nstr,nstb);
rus("Номер строки с первым положительным элементом =>, ");
numberofstr(p,nstr,nstb);
getch();
return 0;
}
void vvod(int **p, int nstr, int nstb)
{ int i,j;
 for(i=0;i<nstr;i++)
  for(j=0;j<nstb;j++)
 {
   cout<<"  mas ["<<i<<"] "<<"["<<j<<"] = "; cin>>p[i][j];
 }
}
 
void str(int **p, int &nstr, int nstb)
{    int i,j,k,t,m;
i=0;
  while(i<nstr){
         k=0;
         for (j=0;j<nstb;j++)
          if (p[i][j]==0){k++ ;}
          if (k == nstb){
                   for (t=0;t<nstb;t++)
                   {
                         for (m=i;m<nstr-1;m++)
                          {
                           p[m][t]=p[m+1][t];
                          }
                   }nstr--;
                }
                i++;
  }
  }
void st(int **p, int nstr, int &nstb)
{    int i,j,k,t,m;
j=0;
  while(j<nstb){
         k=0;
         for (i=0;i<nstr;i++)
          if (p[i][j]==0)k++ ;
          if (k==nstr){
                   for (t=0;t<nstr;t++)
                   {
                   for (m=j;m<nstb-1;m++)
                   {
                          p[m][t]=p[m][t+1];
 
                   }
                   }nstb--;
                 }else j++;
          }
}
void numberofstr(int **p, int nstr, int nstb)
{  int i,j,k=0;
 for(i=0;i<nstr;i++)
 for(j=0;j<nstb;j++)
 {
 if(p[i][j]>0) {k=i; break;}
 else {rus("Нет положительных символов");}
 }
 cout<<k;
}
void outputt(int **p, int nstr, int nstb)
{ int i,j;
  for (i=0;i<nstr;i++){
     cout<<endl<<endl;
        for(j=0;j<nstb;j++)
          cout<<setw(4)<<p[i][j]<<" ";
   }
 
}
Миниатюры
Подкорректируйте код  
0
4 / 4 / 3
Регистрация: 05.09.2011
Сообщений: 113
15.12.2011, 20:30  [ТС]
Причем, если делать без процедур, то все работает нормально, но к сожалению надо с процедурами

Добавлено через 19 часов 48 минут
Не ужели никто не знает как исправить эту ошибку????
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.12.2011, 20:30
Помогаю со студенческими работами здесь

Подкорректируйте код, чтобы случайно распределенные окружности не пересекались
есть код для построения случайным образом окружностей, но они пересекаются, что дописать в коде чтоб они не пересекались и при это...

Среднее арифметическое положительных. Подкорректируйте мой код, пожалуйста
Задана последовательность вещественных чисел. Найти среднее арифметическое положительных чисел. Входные данные В первой строке...

Подкорректируйте сборку
Добрый день дайте консультацию по сборке для игр и по возможности подкорректируйте ее бюджет маленький (30-35к)все будет докупаться по...

Подкорректируйте стили
Привет,вот тут у меня небольшая проблема,делаю форму.Но немножко уезжает лупа,хотелось бы выровнить.Вот код: &lt;html&gt; ...

Проверьте и подкорректируйте
Были в Фирме &quot;Рет&quot;. Посоветовали такую конфигурацию: pentium g2130 3.2/ asus H61M-K звук видео LAN1gb/DDR3 4 gb/ Плюс в него видео:...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
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 и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru