Форум программистов, компьютерный форум, киберфорум
Наши страницы
C# .NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.90/10: Рейтинг темы: голосов - 10, средняя оценка - 4.90
eXhaust
5 / 5 / 2
Регистрация: 28.02.2010
Сообщений: 48
1

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

28.02.2010, 09:45. Просмотров 2070. Ответов 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
QA
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
28.02.2010, 09:45
Ответы с готовыми решениями:

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

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

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

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

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

5
HIMen
4291 / 1459 / 101
Регистрация: 12.04.2009
Сообщений: 2,346
28.02.2010, 11:16 2
Так создаешь массив
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  [ТС] 3
Спасибо, но что делать с этими фрагментами кода?:
C#
1
2
3
int max = A[n-1,0]
max = A[n - 1 - j, j]
int temp = A[i, jmin]
0
HIMen
4291 / 1459 / 101
Регистрация: 12.04.2009
Сообщений: 2,346
28.02.2010, 12:13 4
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  [ТС] 5
Еще раз Огромное Спасибо! Выручил. Все прекрасно работает...
0
SSV
Заблокирован
28.02.2010, 12:42 6
пока сам разбирался уже ответили
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
28.02.2010, 12:42
Answers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.02.2010, 12:42

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

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

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


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

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

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