Форум программистов, компьютерный форум, киберфорум
Наши страницы
C# для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.88/8: Рейтинг темы: голосов - 8, средняя оценка - 4.88
stler
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 30
1

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

28.12.2013, 00:40. Просмотров 1499. Ответов 2
Метки нет (Все метки)

Дорогие форумчани, помогите с задачками, в понедельник зачет, ничего в голову не идет

Для квадратной матрицы размера nxn просуммировать эле-менты, расположенные на диагоналях, параллельных главной, включая главную диагональ. Результат получить в виде вектора размера 2n – 1.

В соревнованиях по прыжкам со 120-метрового трамплина принимает участие не более 30 спортсменов. Судят соревнования 5 судей. Каждый судья выставляет оценку за стиль прыжка по 20-балльной шкале. Меньшая и большая оценки отбрасываются, ос-тальные суммируются. К этой сумме прибавляются очки за даль-ность прыжка: 120 метров – 60 очков, за каждый метр превышения добавляются по 2 очка, при меньшей дальности отнимаются 2 очка за каждый метр. Получить итоговую таблицу соревнований, содержа-щую фамилию и итоговый результат для каждого участника в поряд-ке занятых мест
0
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.12.2013, 00:40
Ответы с готовыми решениями:

Просуммировать элементы, расположенные на диагоналях параллельных главной
Для заданного двумерного массива размером N x N просуммировать элементы, расположенные на...

Найти сумму чисел нижнего треугольника матрицы, включая главную диагональ
Дана матрица A(n,n). Найти сумму чисел нижнего треугольника, включая главную диагональ,...

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

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

Найти наибольшие элементы каждой строки матрицы и поместить их на главную диагональ
Найти наибольшие элементы каждой строки матрицы Z(16,16) и поместить их на главную диагональ....

2
S_el
2289 / 1723 / 361
Регистрация: 15.12.2013
Сообщений: 6,908
28.12.2013, 01:43 2
Лучший ответ Сообщение было отмечено stler как решение

Решение

мое решение 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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
 
namespace C1
{
    class Program
    {
        static double func(ref double[,] mas,int u,int y)
        {
            int i = 0;
            double r = 0;
            for (i = 0; i <= u; i++)
                r = r + mas[y-1-i,i];
            return r;
        }
        static double func2(ref double[,] mas, int u,int y)
        {
            int i = 0;
            double r = 0;
            for (i = 0; i <y-u; i++)
                r = r + mas[i, u+i];
            return r;
        }
        static void Main(string[] args)
        {
            int n;
            Console.WriteLine("Vvedute n");
            n = Convert.ToInt32(Console.ReadLine());
            double[,] array = new double[n, n];
            double[] x = new double[2*n-1];
 
            for (int i = 0; i < n; i++)
            {
                for (int j = 0; j < n; j++)
                {
 
                    array[i,j] = Convert.ToDouble(Console.ReadLine());
                }
            }
            int t = 0;
            for (t = 0; t < n; t++)
                x[t] = func(ref array, t,n);
            
            for (int z = n-1; z>0; z--)
                x[n+z-1] = func2(ref array, z, n);
 
            for (int j = 0; j < (2*n - 1); j++)
            Console.WriteLine(" Summa {1} = {0}", x[j],j);
            Console.ReadLine();
        }
 
    }
}

Не по теме:


C# только начал учить,поэтому код может быть плохо оптимизирован :)


1
Kruds
697 / 697 / 226
Регистрация: 04.03.2013
Сообщений: 1,384
Завершенные тесты: 1
28.12.2013, 15:02 3
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
static void Main()
{
    int matrixSize = 4; //задали размерность матрицы
        
    //заполнение и вывод матрицы на экран
    int  iter = 1;
    int[,] matrix = new int[matrixSize, matrixSize];
    for (int i = 0; i < matrixSize; i++)
    {
        for (int j = 0; j < matrixSize; j++)
        {
            matrix[i, j] = iter++;
            Console.Write("{0}\t", matrix[i, j]);
        }
        Console.WriteLine();
    }
        
    //подсчет сумм диагоналей
    int[] values = new int[2 * matrix.GetLength(0) - 1];
    for (int i = 0; i < matrixSize; i++)
    {
        int sum = 0, sumSimmetr = 0;
        for (int j = 0; j <= i; j++)
        {
            sum += matrix[matrixSize - 1 - i + j, j];
            sumSimmetr += matrix[j, matrixSize - 1 - j];
        }
        values[i] = sum;
        values[values.Length - i - 1] = sumSimmetr;
    }
 
    Console.WriteLine("Суммы диагоналей: {0}", string.Join(", ", values));
    Console.Read();
}

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
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
class Program
{
    static void Main()
    {
        int SportsmansCount = 5;
        CompetitionResult[] results = new CompetitionResult[SportsmansCount];
        for (int i = 0; i < SportsmansCount; i++)
            results[i] = new CompetitionResult();
        BubbleSort(results);
        Console.WriteLine("Name\tDistance\tMarks\tTotal");
        foreach (CompetitionResult result in results)
            Console.WriteLine(result);
        Console.Read();
    }
 
    class CompetitionResult : IComparable<CompetitionResult>
    {
        string Name;
        int Distance;
        int[] Marks;
 
        public CompetitionResult()
        {
            Console.WriteLine("Введите имя спортсмена: ");
            this.Name = Console.ReadLine();
            Console.WriteLine("Введите дальность прыжка: ");
            this.Distance = int.Parse(Console.ReadLine());
            Console.WriteLine("Введите пять оценок (через Enter):");
            this.Marks = new int[5];
            for (int i = 0; i < 5; i++)
                this.Marks[i] = int.Parse(Console.ReadLine());
        }
 
        public int GetTotal()
        {
            int sum = 60, max = int.MinValue, min = int.MaxValue;
            foreach (int mark in this.Marks)
            {
                if (mark < min)
                    min = mark;
                if (mark > max)
                    max = mark;
                sum += mark;
            }
            sum -= (max + min);
 
            if (this.Distance < 120)
                sum -= (120 - Distance) * 2;
            else
                sum += (Distance - 120) * 2;
 
            return sum;
        }
 
        public int CompareTo(CompetitionResult other)
        {
            int pointsCompareResult = this.GetTotal().CompareTo(other.GetTotal());
            if (pointsCompareResult == 0)
                return this.Name.CompareTo(other.Name);
            else
                return pointsCompareResult;
        }
 
        public override string ToString()
        {
            return String.Format("{0}\t{1}\t{2}\t{3}", this.Name, this.Distance, string.Join("; ", this.Marks), this.GetTotal());
        }
    }
 
    static void BubbleSort<T>(T[] array) where T : IComparable<T>
    {
        for (int i = 0; i < array.Length; i++)
            for (int j = i; j < array.Length; j++)
                if (array[i].CompareTo(array[j]) == -1)
                {
                    T tmp = array[i];
                    array[i] = array[j];
                    array[j] = tmp;
                }
    }
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.12.2013, 15:02

Просуммировать элементы матрицы, расположенные на диагоналях, параллельных главной
Для заданного двумерного массива размером N N про- суммировать элементы, расположенные на...

Просуммировать элементы матрицы, расположенные на главной и побочных (соседних с главной) диагоналях.
Составьте программу для решения следующей задачи обработки двумерных массивов произвольной длины....

Просуммировать элементы квадратной матрицы по каждой из линий, параллельных главной диагонали
оформить в виде процедуры и функции


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2019, vBulletin Solutions, Inc.
Рейтинг@Mail.ru