Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.86/14: Рейтинг темы: голосов - 14, средняя оценка - 4.86
 Аватар для eXhaust
5 / 5 / 2
Регистрация: 28.02.2010
Сообщений: 48

Небезопасный код в C#

28.02.2010, 09:45. Показов 2710. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем здравствуйте. Собственно есть задание: Задан стековый массив А(N, N). Поменять местами столбцы, в которых находятся максимальный и минимальный элементы побочной диагонали.. И я его сделал, только в не совсем том виде, в котором нужно. Вообщем помогите пожалуйста переделать в небезопасный код с использованием указателей. Вот исходный код:
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace Work_1
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.Write("Введите кол-во строк и столбцов: ");
            int n = Convert.ToInt32(Console.ReadLine());
            Console.WriteLine("Введите элементы матрицы: ");
            int[,] A = new int[n, n];
            int i, j;
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < n; j++)
                {
                    A[i, j] = Convert.ToInt32(Console.ReadLine());
                }
            }
            Console.WriteLine("Исходная матрица:");
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < n; j++)
                {
                    Console.Write(A[i, j] + " ");
                }
                Console.WriteLine();
            }
            Console.WriteLine("===============");
            //определяем максимальный элемент в побочной диагонали и номер столбца
            int max = A[n-1,0];
            int jmax=0;
            for (j = 0; j < n; j++)
            {
                if (A[n - 1 - j, j] > max)
                {
                    max = A[n - 1 - j, j];
                    jmax = j;
                }
            }
            //определяем минимальный элемент в побочной диагонали и номер столбца
            int min = A[n - 1, 0];
            int jmin = 0;
            for (j = 0; j < n; j++)
            {
                if (A[n - 1 - j, j] < min)
                {
                    min = A[n - 1 - j, j];
                    jmin = j;
                }
            }
            //Меняем столбцы местами
            for (i = 0; i < n; i++)
            {
                int temp = A[i, jmin];
                A[i, jmin] = A[i, jmax];
                A[i, jmax] = temp;
            }
            if (max == min)
                Console.WriteLine("Максимальный и минимальный элементы одинаковы");
            Console.WriteLine("Результат: ");
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < n; j++)
                {         
                    Console.Write(A[i, j] + " ");
                }
                Console.WriteLine();
            }
        }
    }
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.02.2010, 09:45
Ответы с готовыми решениями:

Небезопасный код
Всем привет, интересует такой вопрос. Мне нужно создать public partial class MyForm : Form { Dictionary&lt;string,...

Безопасный и небезопасный код.
Есть некий класс unsafe class MyClass { //... public void SetKey(byte Key) { //... ...

Небезопасный код: пример из книги не компилируется
Учу с# по книге Шилдта, в разделе про небезопасный код есть примеры работы с указателями, однако данный код не компилируется в Visual...

5
 Аватар для HIMen
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
28.02.2010, 11:16
Так создаешь массив
C#
1
int* A = stackalloc int[n * n];
Двумерных не бывает поэтому [i, j] превратится в [n * i + j]
0
 Аватар для eXhaust
5 / 5 / 2
Регистрация: 28.02.2010
Сообщений: 48
28.02.2010, 12:06  [ТС]
Спасибо, но что делать с этими фрагментами кода?:
C#
1
2
3
int max = A[n-1,0]
max = A[n - 1 - j, j]
int temp = A[i, jmin]
0
 Аватар для HIMen
4340 / 1509 / 101
Регистрация: 12.04.2009
Сообщений: 2,342
28.02.2010, 12:13
C#
1
2
3
int max = A[n*(n-1)]
max = A[n*(n - 1 - j)+ j]
int temp = A[n*i+ jmin]
0
 Аватар для eXhaust
5 / 5 / 2
Регистрация: 28.02.2010
Сообщений: 48
28.02.2010, 12:29  [ТС]
Еще раз Огромное Спасибо! Выручил. Все прекрасно работает...
0
Заблокирован
28.02.2010, 12:42
пока сам разбирался уже ответили
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
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace Work_1
{
    class Program
    {
        static void Main(string[] args)
        {
            Main2();
            Console.ReadKey();
        }
       static public unsafe void Main2()
        {
            Console.Write("Введите кол-во строк и столбцов: ");
            int n = Convert.ToInt32(Console.ReadLine());
            Console.WriteLine("Введите элементы матрицы: ");
           
            int[,] A = new int[n, n];
          
            int i, j;
           
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < n; j++)
                {
                    A[i, j] = Convert.ToInt32(Console.ReadLine());
                }
            }
            Console.WriteLine("Исходная матрица:");
           
           
                for (i = 0; i < n; i++)
                {
                    for (j = 0; j < n; j++)
                    {
 
                        Console.Write(A[i, j] + " ");
                    }
                    Console.WriteLine();
                }
            
            Console.WriteLine("===============");
            //определяем максимальный элемент в побочной диагонали и номер столбца
            int max = A[n - 1, 0];
            int jmax = 0;
            for (j = 0; j < n; j++)
            {
                if (A[n - 1 - j, j] > max)
                {
                    max = A[n - 1 - j, j];
                    jmax = j;
                }
            }
            //определяем минимальный элемент в побочной диагонали и номер столбца
            int min = A[n - 1, 0];
            int jmin = 0;
            for (j = 0; j < n; j++)
            {
                if (A[n - 1 - j, j] < min)
                {
                    min = A[n - 1 - j, j];
                    jmin = j;
                }
            }
            //Меняем столбцы местами
            for (i = 0; i < n; i++)
            {
                int temp = A[i, jmin];
                A[i, jmin] = A[i, jmax];
                A[i, jmax] = temp;
            }
            if (max == min)
                Console.WriteLine("Максимальный и минимальный элементы одинаковы");
            Console.WriteLine("Результат: ");
            for (i = 0; i < n; i++)
            {
                for (j = 0; j < n; j++)
                {
                    // ИСПОЛЬЗУЕМ УКАЗАТЕЛИ
                    int* pI = (int*)A[i, j];
                    Console.Write((int)pI + " ");
                }
                Console.WriteLine();
            }
        }
    }
}
В свойствах проекта на вкладке Построение поставишь галочку "Разрешить небезопасный код"
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.02.2010, 12:42
Помогаю со студенческими работами здесь

Небезопасный код. Битовое чтение файла и преобразование к определенному формату
Доброго времени суток. Решаю задачу битового чтения файла и преобразование к определенному формату. Реализовал следующим образом ...

небезопасный код (unsafe)
Столкнулся с проблемой: Visual Studio 2010 ругается на unsafe, а именно: &quot;ошибка CS0227: Небезопасный код может использоваться только при...

SharpDevelop и небезопасный код
Привет всем. Подскажите пожалуйста как разрешить небезопасный код в SharpDevelop Поиск по форуму дает ответ только для VS :wall: ...

Небезопасный код с использованием указателей (операции с массивами)
Задан стековый массив А(N). Получить из него массив В(M), содержащий элементы массива А, кратные двум. Помогите переделать код в...

Небезопасный код, многоуровневая адресация - каково их назначение
Зачем она и с чем ее едят? Неужели бывают случаи когда нужно иметь адрес адреса? //с &quot;С&quot; знаком плохо,опыта нет,по-этому и...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! в-строка - входное арифметическое выражение в инфиксной(обычной). . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru