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

Удаление из матрицы столбцов. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Склонение существительного http://www.cyberforum.ru/cpp-beginners/thread171850.html
Проходим оператор switch... В зависимости от целого числа просклонять заданное существительное. ....Ну это,как я понимаю,типа вводим существительное- книга и любое число,например,-11.И программа должна вывести 11 книг. если 2,то 2 книги. .....Что-то как то не очень в голове укладывается,помогите пожалуйста!!!Как составить программу( Добавлено через 1 минуту е если 1003,то 1003...
C++ Поиск и замена максимального элемента двумерного массива Добрый день, надо написать динамический массив который находит максимальный элемент и меняет его с элементом A. http://www.cyberforum.ru/cpp-beginners/thread171848.html
C++ Список
Доброго всем времени суток. Столкнулся с таким вот заданием: сформировать документ,в котором сохраняется информация о заболеваемости сотрудников:Ф.И.О, год рождеия,заболевание,длительность болезни.На его основе сформировать список сотрудников,которые перенесли одно и то же заболевание. Есть код интерфейса АТД "Список" template <class Item,class Key> class List { private: // программный...
C++ Склеивание двух vector'ов
Имеется два экземпляра класса std::vector. Я хочу один вектор прицепить к другому. Т..е на входе имеем вектора {1,2,3} и {4,5,6}, а хочется получить вектор {1,2,3,4,5,6}. Сейчас я обхожу поэлементно второй вектор и добавляю к первому, но это велосипед. Можно ли это сделать по-человечески?
C++ Вычислить произведение последних 3-х чисел не кратных 5 в диапазоне от 20 до 50 http://www.cyberforum.ru/cpp-beginners/thread171835.html
Всем привет! Мне дана задача, но я незнаю как в С++ обозначать диапазоны и через какой цикл писать. У меня 2 варианта, но я склоняюсь ко 2 варианту. Вычислить произведение последних 3-х чисел не кратных 5 в диапазоне от 20 до 50. Вариант 1 #include "stdafx.h" #include <iostream> using namespace int _tmain(int argc, _TCHAR* argv)
C++ Программа для отыскания заданного количества пар дружественных чисел Два числа называют дружественными, если каждое из них равно сумме всех делителей другого, кроме самого этого числа. Например, 220 и 284 есть дружественные числа, так как делителями первого являются числа 1 2 4 5 10 11 20 22 44 55 110, сумма которых равно 284, а делителями второго - числа 1 2 4 71 142, которые в сумме дают 220. Напишите программу для отыскания заданного количества пар... подробнее

Показать сообщение отдельно
Alauda
Сообщений: n/a
03.10.2010, 15:08     Удаление из матрицы столбцов.
Добрый день! Помогите пожалуйста с заданием на С++. Перепробовала уже все на что способна, а все равно не получается((( Конечный вариант текста программы ниже.
Задание звучит так:
Дана матрица A=(aij)mxn. Сформировать матрицу B=(bij) mxn , исключив из матрицы A столбцы, содержащие элементы равные 1. Сформировать вектор D=(d1, d2 ,…, dn) из номеров столбцов, матрицы A, содержащих элементы равные 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
#include <iostream.h>
#include <conio.h>
#include <stdio.h>
int m,n,l,k=0,p=0;
float **A,**B;
int *D,*C;
void vvod(void)
{k=0;
for (int i=0;i<n;i++)
  for (int j=0;j<m;j++)
 {
 cout<<"vvedite A["<<i<<","<<j<<"]  ";
 cin>>*(*(A+i)+j);
 }
}
void ravno(void)
{
for (int j=0;j<m;j++)
  {
  for (int i=0;i<n;i++)
    {
     if(A[j][i]==1)
    { C[i]=1;
      D[k]=i;
      k++;
     }
     else
       C[i]=0;
    }
  l=k;
  }
return;
}
 
void main(void)
{
void vivod(void);
clrscr();
cout<<"Vvedite razmernost matric:\n";
cout<<"Chislo strok N= ";
cin>>n;
cout<<"Chislo stolbcov M= ";
cin>>m;
cout<<"\n";
A=new float *[n];
  for (int j=0;j<m;j++)
   A[j]=new float[m];
vvod();
ravno();
vivod();
for (int t=0;t<m;t++)
 {
 delete A[t];
 
 }
delete[] A;
 
cout<<"\nNagmite lubuyu klavishu";
getch();
return;
}
void vivod (void)
{
cout<<"Vector D=";
  for(int i=0; i<l; i++)
  cout<<D[i]<<" ";
  cout<<endl;
cout<<"C=";
 { for(int i=0; i<n; i++)
   cout<<C[i]<<" ";
   cout <<endl;}
cout<<"Matrica B:\n";
 
for (int j=0;j<m;j++)
  {
  for (int i=0;i<n;i++)
     if (C[i]==1)
       for (int r=i;r<=n;r++)
    A[j][r]=A[j][r+1];
     else
     A[j][i]=A[j][i];}
    // continue; }
     //{A[j][i]=A[j-k][i];
    {for (int j=0;j<m;j++)
    {for (int i=0;i<n-l;i++)
     cout<<A[j][i]<<" ";
     cout<<endl;
  }
cout<<"\nAdres matricy B:\n";
{for (int j=0;j<m;j++)
{
for (int i=0;i<n-l;i++)
cout<<&A[j][i]<<" ";
cout<<endl;}
}
 
}
return;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru