Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/6: Рейтинг темы: голосов - 6, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 05.12.2016
Сообщений: 10

Программа обработки массива, считываемого из файла: посчитать ниже побочной диагонали

13.12.2017, 19:37. Показов 1143. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Задание для самостоятельной работы
Написать программу обработки массива, считываемого из файла. Программа должна выполнять операции:
1) ввод матрицы из файла,
2) нахождение характеристики матрицы в соответствии с вариантом,
4) преобразование матрицы в соответствии с вариантом,
5) печать матрицы,
6) выход.
Выбор операции производится с использованием меню

В строке где нужно заменить элементы ниже побочной диагонали на еденицы
C#
1
 if (i + j > n - 1) { a[i, j] = 1; }
, не знаю как записать, пишет что оператор " - " невозможно применить к оператору типа object и 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
namespace ConsoleApp1
{
    class Program
    {
        static void Main(string[] args)
        {
            string line;
            char[] delimiterChars = { ' ', ',', '\t' };
            int n; int[,] matr;
            int i, j;
            using (StreamReader file = new StreamReader("dat.txt"))
            {
                n = int.Parse(file.ReadLine()); matr = new int[n, n];
                for (i = 0; (i < n) && ((line = file.ReadLine()) != null); i++)
                {
                    string[] numbers = line.Split(delimiterChars); j = 0;
                    foreach (string numString in numbers)
                    {
                        int x;
                        bool canConvert = int.TryParse(numString, out x);
                        if (canConvert == true)
                        {
                            matr[i, j] = x; j++;
                        }
                    }
                }
            }
            string choice = "0";
            while (choice != "4")
            {
                Console.WriteLine();
                Console.WriteLine("1. Печать матрицы");
                Console.WriteLine("2. найти произведение ненулевых элементов матрицы");
                Console.WriteLine("3. заменить элементы ниже побочной диагонали значением 1");
                Console.WriteLine("4. Выход");
                Console.WriteLine(" ");
                Console.WriteLine(" Введите номер пункта меню "); choice = Console.ReadLine();
                switch (choice)
                {
                    case "1":
                        Console.WriteLine(" Печать матрицы");
                        print_matrica(matr);
                        Console.WriteLine();
                        break;
                    case "2":
                        Console.Write("произведение ненулевых элементов матрицы = {0}", Kolvo(matr));
                        Console.WriteLine();
                        break;
                    case "3":
                        Console.WriteLine(" Произведена замена.");
                        zamena(ref matr);
                        Console.WriteLine();
                        break;
                    case "4":
                        Console.WriteLine(" До свидания!");
                        break;
                    default:
                        Console.WriteLine(" Введите 1, 2, 3 или 4");
                        Console.WriteLine();
                        break;
                }
            }
            Console.ReadLine();
        }
        static int Kolvo(int[,] a)
        {
            int k = 0;
            for (int i = 0; i < a.GetLength(0); i++)
            {
                for (int j = 0; j < a.GetLength(1); j++)
                {
                    if (a[i, j] != 0) { k *= a[i, j]; }
                }
            } return k;
        }
        static void zamena(ref int[,] a)
        {
            
            for (int i = 0; i < a.GetLength(0); i++)
            {
                for (int j = 0; j < a.GetLength(1); j++)
                {
                    if (i + j > n - 1) { a[i, j] = 1; }
                }
            } 
        }
        static void print_matrica(int[,] a)
        {
            for (int i = 0; i < a.GetLength(0); i++)
            {
                for (int j = 0; j < a.GetLength(1); j++)
                {
                    Console.Write("{0} \t", a[i, j]);
                }
                Console.WriteLine();
            }
        }
 
        public static object n { get; set; }
 
        public static int j { get; set; }
    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
13.12.2017, 19:37
Ответы с готовыми решениями:

Поместить элементы из первого массива выше и на побочной диагонали матрицы, а из второго массива ниже побочной
Сгенерировать две последовательности А и В из 15 и 10 случайных целых чисел соответственно. Сформировать из этих последовательностей...

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

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

2
 Аватар для ViterAlex
8951 / 4863 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
13.12.2017, 20:17
У тебя в 99 строке n объявлена как object. Зачем?
0
3566 / 2507 / 1174
Регистрация: 14.08.2016
Сообщений: 8,219
13.12.2017, 20:31
в область видимости метода zamena попадает только некое свойство n типа object, его то он и берется сравнивать с int
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
13.12.2017, 20:31
Помогаю со студенческими работами здесь

Найти максимальные из элементов, расположенных на побочной диагонали и выше, на побочной диагонали и ниже
Опыта работы с матрицами пока мало, поэтому прошу помощи. Ребят, помогите пожалуйста! Дана квадратная матрица , размер которой...

Посчитать сумму элементов каждой диагонали двумерного массива, параллельной побочной диагонали
Здравствуйте уважаемые пользователи форума. Помогите пожалуйста с решением задачи по C#: &quot;Дана квадратная матрица A порядка M. Найти...

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

Заполнить нулями матрицу на побочной диагонали и ниже побочной диагонали
Заполнить матрицу из 7 строк и 7 столбцов случайными числами в интервале и вывести ее на экран. Обнулить элементы, отмеченные зеленым...

Вывести на экран часть массива, расположенную ниже побочной диагонали.
Дан двухмерный массив размером 10 х 10, Вывести на экран часть массива:расположенную ниже побочной диагонали. напишите пожалуйста лишь...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru