С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/25: Рейтинг темы: голосов - 25, средняя оценка - 4.56
0 / 0 / 1
Регистрация: 01.03.2016
Сообщений: 3

Вывод двумерного массива в TextBox

01.03.2016, 20:07. Показов 4996. Ответов 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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
 
namespace Spiral_form
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
 
        private void Form1_Load(object sender, EventArgs e)
        {
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
            string s = textBox1.Text;
            int n = s.Length;
            char[] arr1 = new char[n];
            arr1 = s.ToCharArray(0, s.Length); // закидываю слово в массив
 
            char[,] matr = new char[n, n];
 
            int i, j, sch = 0;
 
            for (j = 0, i = 0; j < n; j++) // заполняю первую строку вправо
            {
                if (sch == n) // проверка, если достигли конца слова, 
                {
                    sch = 0; // обнуляем массив, чтобы писать слово сначала (иначе бы вылезли за пределы массива)
                }
                matr[i, j] = arr1[sch];
                sch++;
            }
 
            for (i = 1, j = n - 1; i < n - 1; i++) // заполняю последний столбец вниз
            {
                if (sch == n) // проверка, если достигли конца слова, 
                {
                    sch = 0; // обнуляем массив, чтобы писать слово сначала (иначе бы вылезли за пределы массива)
                }
                matr[i, j] = arr1[sch];
                sch++;
            }
 
            for (j = n - 1, i = n - 1; j >= 0; j--) // заполняю последнюю строку влево
            {
                if (sch == n) // проверка, если достигли конца слова, 
                {
                    sch = 0; // обнуляем массив, чтобы писать слово сначала (иначе бы вылезли за пределы массива)
                }
                matr[i, j] = arr1[sch];
                sch++;
            }
 
            int count = 3; // счетчик №2
            int c = 0;
 
            i = n - 1;
            j = 0;
 
            for (int x = n - 3; x > 0; x -= 2) // это просто проверка, чтобы запустить всё что ниже
            {
                if (n % 2 == 0 & x == 1) // если длина нашего слова при делении на 2, дает остаток 0, и х равен 1 то с = 1 иначе 0
                    c = 1;
                else
                    c = 0;
 
                while (c < 2) // проверка выше нужна, чтобы это работало, работа завершится, если 'c' станет = 3 
                {
                    switch (count) // переключатель, то чему равно count, будет вызываться соответствующий case
                    {
                        case 1: //Вниз, если count = 1
                            for (int t = 0; t < x; t++) // цикл перемещения
                            {
                                i++;
                                {
                                    if (sch == n) // эта всё та же проверка на окончание слова
                                    {
                                        sch = 0;
                                    }
                                    matr[i, j] = arr1[sch++];
                                }
                            }
                            count++;
                            break;
                        case 2: //Влево
                            for (int t = 0; t < x; t++)
                            {
                                j--;
                                {
                                    if (sch == n)
                                    {
                                        sch = 0;
                                    }
                                    matr[i, j] = arr1[sch++];
                                }
                            }
 
                            count++;
                            break;
                        case 3: //Вверх
                            for (int t = 0; t < x; t++)
                            {
                                i--;
                                {
                                    if (sch == n)
                                    {
                                        sch = 0;
                                    }
                                    matr[i, j] = arr1[sch++];
                                }
                            }
 
                            count++;
                            break;
                        case 4: //Вправо
                            for (int t = 0; t < x; t++)
                            {
                                j++;
                                {
                                    if (sch == n)
                                    {
                                        sch = 0;
                                    }
                                    matr[i, j] = arr1[sch++];
                                }
                            }
                            count = 1;
                            break;
                    }
                    c++;
                }
            }
 
            for (int p = 0; p < s.Length; p++)
            {
                for (int v = 0; v < s.Length; v++)
                {
                    if (matr[p, v] != 0)
                       richTextBox1.AppendText(System.String.Format(Convert.ToString(matr[p, v]) + "\t")); 
//жалкие попытки что-то вывести
// если элемент матрицы не равен нулю, то есть просто существует, вывожу побуквенно слово
                    else
                        richTextBox1.Text = (" ") ; // пробел в другом случае
                }
            }
        }
 
        private void textBox1_TextChanged(object sender, EventArgs e)
        {
 
        }
 
    }
 
}
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
01.03.2016, 20:07
Ответы с готовыми решениями:

Вывод двумерного массива в TextBox
всем привет, подскажите пожалста, где у меня в коде косяк? выводится почему-то только последний элемент массива private void...

Вывод двумерного ступенчатого массива в textbox
Не получается вывести двумерный ступенчатый массив в текстбокс. Проблема в 18 строке. private void button2_Click_1(object sender,...

Ввод двумерного массива с клавиатуры через TextBox
Привет всем. Парни есть: int MyArray; int n; public Massiv(int N) { this.n = N; ...

2
290 / 271 / 107
Регистрация: 10.06.2011
Сообщений: 696
01.03.2016, 21:49
C#
1
2
3
4
5
6
7
8
9
10
String out=String.Empty;
for(int i=0;i<n;i++)
{
 for(int j=0;j<0;j++)
 {
  out+=matr[i,j]+" ";
 }
 out+=Envirlopment.NewLine;
}
TextBoxOut.Text=out;
0
0 / 0 / 1
Регистрация: 01.03.2016
Сообщений: 3
02.03.2016, 09:33  [ТС]
+15 ошибок, или я просто не туда вставляю(
Можно с комментариями? Буду очень благодарна!)

Добавлено через 11 часов 30 минут
Нашла решение:
C#
1
2
3
4
5
6
7
8
9
10
11
12
 for (int p = 0; p < s.Length; p++)
            {
                for (int v = 0; v < s.Length; v++)
                {
                    if (matr[p, v] != 0)
                        richTextBox1.AppendText(matr[p, v].ToString());// если элемент матрицы не равен нулю, то есть просто существует, вывожу побуквенно слово
                    else
                        richTextBox1.AppendText(" "); // пробел в другом случае
                   
                }
                richTextBox1.AppendText("\n");
            }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
02.03.2016, 09:33
Помогаю со студенческими работами здесь

Ввод двумерного массива (20х15) с помощью динамических textBox
Помогите пожалуйста c заданием я нуб Двумерный массив (20х15). Все компоненты на форме создаются только программно !!! (То есть в...

Вывод двумерного массива в textbox
Всем привет! Вот только начал работать с интерфейсом в PascalABC. Хочу сделать калькулятор, но не могу разобраться, как написать код для...

Функции двумерного массива. Транспонировать матрицу через ввод вывод функции двумерного массива.
Транспонировать матрицу через ввод вывод функции двумерного массива.Сначала вывести ее,а потом провести транспонирование.

Считывание двумерного массива из TextBox
Помогите, как сделать что бы при вводе матрицы в textbox программа считала ее в двумерный массив ?

Формирование и вывод на экран одномерного массива, состоящего из полусумм строк двумерного массива
:gsorry:помогите.... Составьте программу формирования и вывода на экран одномерного массива,состоящего из полусумм строк двумерного...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru