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

Удаление главной диагонали - C++

Восстановить пароль Регистрация
 
egorlp
5 / 5 / 1
Регистрация: 09.05.2010
Сообщений: 43
14.11.2010, 15:04     Удаление главной диагонали #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
#include "stdafx.h"
#include <conio.h>
#include <iostream>
#include <math.h>
#include <time.h>
using namespace std;
 
 
 
int main( void )
{
        srand (time(NULL));
        float **a;
        int  n;
        cout<<"n> ";
        cin>>n; 
        cout<<endl;
        if (n<0) n=abs(n);
 
        cout<<endl;
        a=new float* [n];
        for (int i=0;i<n;i++)
        {
                a[i]=new float[n];
             for (int j=0;j<n;j++)
             {
                  a[i][j]=rand()%50+10;//+float((rand()%100))/100;
                          cout<<a[i][j]<<" ";
             }
                 cout<<endl;
        }
   for (int i=0;i<n;i++)
        {
     for (int j=0;j<n;j++)
         {
             if (i=j) };
        
        
 delete [a[i]] }
Когда пишу в delete еще и j, пишет что j - необьявлено. Помогите, если можете. Я знаю как это осуществить на Паскале, а вот с представлением данной задачи на С++ возникла проблема, т.к. еще не совсем освоился в нем.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
14.11.2010, 15:04     Удаление главной диагонали
Посмотрите здесь:

C++ Разместить на главной диагонали матрицы суммы элементов, лежщих на диагоналях, перпендикулярных к главной
Отсортировать диагонали матрицы,расположенные выше главной, по убыванию элементов, а диагонали матрицы, расположенные ниже главной, по возрастанию C++
Элементы, расположеные на главной диагонали, в первых 3 строках выше диагонали и в последних 2 строках ниже диагонали переместить в одномерный массив C++
C++ вычислить сумму элементов матрицы над главной диагональю под главной диагональю и на главной диагонали
Вывести на экран значения тех эле-ментов, лежащих выше главной диагонали, которые больше всех элементов, лежащих ниже главной диагонали C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Kastaneda
Модератор
Эксперт С++
 Аватар для Kastaneda
4236 / 2769 / 218
Регистрация: 12.12.2009
Сообщений: 7,104
Записей в блоге: 1
Завершенные тесты: 1
14.11.2010, 16:51     Удаление главной диагонали #2
Весь код не смотрел, но по поводу
Когда пишу в delete еще и j, пишет что j - необьявлено
могу сказать, что во первых - j существует только в теле цикла
C++
1
2
3
for (int j=0;j<n;j++)
{
if (i=j) };
за его пределами j нет
во вторых - так массивы не освобождаются, нужно делать вот так:
C++
1
delete []a;
Добавлено через 1 минуту
посмотрел код, что-то мне подсказывает, что строкой "delete[a[i]]"вы хотели удалить один элемент массива, я прав?
Jupiter
Каратель
Эксперт C++
6543 / 3963 / 226
Регистрация: 26.03.2010
Сообщений: 9,273
Записей в блоге: 1
Завершенные тесты: 2
14.11.2010, 16:55     Удаление главной диагонали #3
за его пределами j нет
Kastaneda, ну это смотря в каком компиляторе, в древнем Турбо С++ такое возможно

Добавлено через 49 секунд
Впрочем у ТС явно не Турбо С++)
Kastaneda
14.11.2010, 17:10
  #4

Не по теме:

Цитата Сообщение от Maxwe11 Посмотреть сообщение
в древнем Турбо С++ такое возможно
Но ведь это не по стандарту!!?

egorlp
5 / 5 / 1
Регистрация: 09.05.2010
Сообщений: 43
14.11.2010, 17:37  [ТС]     Удаление главной диагонали #5
Цитата Сообщение от Kastaneda Посмотреть сообщение
Весь код не смотрел, но по поводу

могу сказать, что во первых - j существует только в теле цикла
C++
1
2
3
for (int j=0;j<n;j++)
{
if (i=j) };
за его пределами j нет
во вторых - так массивы не освобождаются, нужно делать вот так:
C++
1
delete []a;

т.е. мне нужно delete занести в for.

Цитата Сообщение от Kastaneda Посмотреть сообщение
Добавлено через 1 минуту
посмотрел код, что-то мне подсказывает, что строкой "delete[a[i]]"вы хотели удалить один элемент массива, я прав?
Разве один элемент? Ведь в цикле идет приращение, т.е. будут рассматриваться все значения
egorlp
5 / 5 / 1
Регистрация: 09.05.2010
Сообщений: 43
16.11.2010, 14:35  [ТС]     Удаление главной диагонали #6
Ух, а самое главное то забыл написать) , нужно удалить главную диагональ.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
16.11.2010, 14:55     Удаление главной диагонали #7
egorlp, Что значит удалить главную диагональ? Обнулить элементы главной диагонали?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
16.11.2010, 15:40     Удаление главной диагонали
Еще ссылки по теме:

Верно ли, что среднее арифметическое элементов выше главной диагонали больше среднего арифметического элементов ниже главной диагонали C++
Определить: сумма элементов выше главной диагонали меньше суммы элементов ниже главной диагонали? C++
Обменять элементы массива на главной диагонали с элементами на побочной диагонали C++

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

Или воспользуйтесь поиском по форуму:
egorlp
5 / 5 / 1
Регистрация: 09.05.2010
Сообщений: 43
16.11.2010, 15:40  [ТС]     Удаление главной диагонали #8
Условие: Дана вещественная матрица N*N. Удалить из матрицы жлементы главной диагонали.
Yandex
Объявления
16.11.2010, 15:40     Удаление главной диагонали
Ответ Создать тему
Опции темы

Текущее время: 03:08. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru