0 / 0 / 1
Регистрация: 30.05.2011
Сообщений: 12

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

29.11.2011, 19:16. Показов 1263. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Решаю такую задачу: в квадратной матрице для каждой строки найти минимальный элемент и переставить его с элементом, стоящим в этой строке на главной диагонали. Но есть небольшой косяк, программа не меняет местами минимальный элемент и элемент на главной диагонали, а просто на главную диагональ записывает минимальный элемент, а ячейка с минимальным остается без изменения. Помогите пожалуйста разобраться что не так.
Delphi
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
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls, Grids;
 
type
  TForm1 = class(TForm)
    Edit1: TEdit;
    Label1: TLabel;
    GroupBox1: TGroupBox;
    StringGrid1: TStringGrid;
    GroupBox2: TGroupBox;
    StringGrid2: TStringGrid;
    RadioGroup1: TRadioGroup;
    Button1: TButton;
    Button2: TButton;
    procedure Button2Click(Sender: TObject);
    procedure RadioGroup1Click(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
const n=50;
var
  Form1: TForm1;
  i,j:integer;
implementation
 
{$R *.dfm}
 
procedure TForm1.Button2Click(Sender: TObject);
begin
stringgrid1.ColCount:=strtoint(edit1.Text);
stringgrid1.RowCount:=strtoint(edit1.Text);
stringgrid2.ColCount:=strtoint(edit1.Text);
stringgrid2.RowCount:=strtoint(edit1.Text);
end;
 
procedure TForm1.RadioGroup1Click(Sender: TObject);
begin
randomize;
if radiogroup1.ItemIndex=0 then
  begin
  for j:=0 to strtoint(edit1.Text)-1 do
  for i:=0 to strtoint(edit1.text)-1 do
  stringgrid1.Cells [i,j]:=inttostr(random(n)-25);
  end;
if radiogroup1.ItemIndex=1 then
  stringgrid1.Options:=stringgrid1.Options +[goEditing];
end;
 
procedure TForm1.Button1Click(Sender: TObject);
var
a:integer;
min:array[1..n] of integer;
begin
  for j:=0 to strtoint(edit1.Text)-1 do
  for i:=0 to strtoint(edit1.text)-1 do
  stringgrid2.Cells [i,j]:=stringgrid1.Cells[i,j];
for i:=0 to strtoint(edit1.Text)-1 do
begin
min[i]:=100;
for j:=0 to strtoint(edit1.Text)-1 do
if strtoint(stringgrid2.Cells[j,i])<min[i] then
min[i]:=strtoint(stringgrid2.cells[j,i]);
end;
for i:=0 to strtoint(edit1.Text)-1 do
begin
for j:=0 to strtoint(edit1.Text)-1 do
begin
if j=i then begin
stringgrid2.Cells [j,i]:=inttostr(min[i]);
 
end;
end;
end;
end;
 
end.
Добавлено через 23 часа 11 минут
Неужели никто помочь не может?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.11.2011, 19:16
Ответы с готовыми решениями:

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

Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали в этой же строке
Дана целочисленная квадратная матрица. Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали в этой...

В матрице найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали
Дана целочисленная квадратная матрица. Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали. ...

2
Почетный модератор
 Аватар для Lord_Voodoo
8784 / 2537 / 144
Регистрация: 07.03.2007
Сообщений: 11,873
29.11.2011, 19:33
Sp1keR, обычно хватает дополнительной переменной для обмена данными между элементами массива, т.е.
Delphi
1
2
3
tmp := x1; 
x1 :=  x2;
x2 := tmp;
а у вас походу идет простое присваивание элементу на главной диагонали минимального элемента...
0
0 / 0 / 1
Регистрация: 30.05.2011
Сообщений: 12
29.11.2011, 21:37  [ТС]
Это я знаю, но запутался уже до такой степени, что не могу уже разобраться. Поэтому и прошу помощи.

Добавлено через 1 час 55 минут
Разобрался сам, вот решение, вдруг кому пригодится.
Delphi
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
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls, Grids;
 
type
  TForm1 = class(TForm)
    Edit1: TEdit;
    Label1: TLabel;
    GroupBox1: TGroupBox;
    StringGrid1: TStringGrid;
    GroupBox2: TGroupBox;
    StringGrid2: TStringGrid;
    RadioGroup1: TRadioGroup;
    Button1: TButton;
    Button2: TButton;
    procedure Button2Click(Sender: TObject);
    procedure RadioGroup1Click(Sender: TObject);
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
const n=50;
var
  Form1: TForm1;
  i,j:integer;
implementation
 
{$R *.dfm}
 
procedure TForm1.Button2Click(Sender: TObject);
begin
stringgrid1.ColCount:=strtoint(edit1.Text);
stringgrid1.RowCount:=strtoint(edit1.Text);
stringgrid2.ColCount:=strtoint(edit1.Text);
stringgrid2.RowCount:=strtoint(edit1.Text);
end;
 
procedure TForm1.RadioGroup1Click(Sender: TObject);
begin
randomize;
if radiogroup1.ItemIndex=0 then
  begin
  for j:=0 to strtoint(edit1.Text)-1 do
  for i:=0 to strtoint(edit1.text)-1 do
  stringgrid1.Cells [i,j]:=inttostr(random(n)-25);
  end;
if radiogroup1.ItemIndex=1 then
  stringgrid1.Options:=stringgrid1.Options +[goEditing];
end;
 
procedure TForm1.Button1Click(Sender: TObject);
var min,m,k:array [0..n-1] of integer;
 
begin
for i:=0 to strtoint(edit1.Text)-1 do
for j:=0 to strtoint(edit1.Text)-1 do
stringgrid2.cells[j,i]:=stringgrid1.cells[j,i];
for i:=0 to strtoint(edit1.Text)-1 do
begin
min[i]:=100;
for j:=0 to strtoint(edit1.Text)-1 do
if strtoint(stringgrid1.Cells[j,i])<min[i] then
begin
m[i]:=i;k[i]:=j;
min[i]:=strtoint(stringgrid1.Cells[j,i]);
end;
end;
 
for i:=0 to strtoint(edit1.Text)-1 do
for j:=0 to strtoint(edit1.Text)-1 do
if j=i then begin
stringgrid2.Cells[k[i],m[i]]:=stringgrid2.Cells[j,i];
stringgrid2.Cells[j,i]:=inttostr(min[i]);
end;
end;
 
end.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.11.2011, 21:37
Помогаю со студенческими работами здесь

В квадратной матрице в каждой строке поменять местами максимальный элемент с элементом на главной диагонали.
Доброго времени суток! :) Задача такая: В квадратной матрице C(MxM) в каждой строке поменять местами максимальный элемент с элементом...

Найти максимальный элемент каждой строки, и поменять его с элементом этой строки, стоящим в последнем столбце
Ув прогрммисты. Сижу на экзамене очень прошу напишите программу. дана квадратная матрица размером n*n. Найти максимальный елемент...

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

Найти в каждой строке наибольший элемент и поменять его местами с элементом главной диагонали
Двумерные массивы, условие в заголовке! Заранее спасибо)

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


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

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

Новые блоги и статьи
Динамические массивы в C++ - создание и использование
NullReferenced 27.04.2025
Динамические массивы представляют собой один из фундаментальных инструментов программирования на C++, позволяющий создавать структуры данных, размер которых определяется во время выполнения. . .
Асинхронный JavaScript: Промисы, Async/Await и Fetch API
Reangularity 27.04.2025
Пользователь заходит на веб-страницу, нажимает кнопку и. . . ничего не происходит. Сайт словно замер. Через несколько секунд всё внезапно оживает, но пользователь уже успел закрыть вкладку. Знакомая. . .
Management on GitLab and repository management in Visual Studio code
jigi33 27.04.2025
- repo management on GitLab - CI/ CD in GitLab - VCS repository management in Visual Studio code (see attachments)
Kanban или Scrum - что выбрать?
EggHead 27.04.2025
Kanban и Scrum — уже много лет удерживают лидирующие позиции среди гибких подходов. Руководители проектов и команды разработчиков то и дело сталкиваются с дилеммой: какой из этих двух методов выбрать. . .
Кастомные Middleware на C# в ASP.NET Core
UnmanagedCoder 27.04.2025
Разработка веб-приложений сегодня мало напоминает монолитное программирование прошлых лет. На смену громоздким блокам кода пришла модульная архитектура, где каждый компонент выполняет строго. . .
Анализ и линтинг кода JavaScript: ESLint, Prettier и JSHint
run.dev 26.04.2025
JavaScript прошёл долгий путь от простого языка для анимации веб-страниц до основы современной веб-разработки. С ростом сложности приложений, увеличением кодовых баз и масштабированием команд. . .
Паттерны в Python: Singleton, Factory и Observer
py-thonny 26.04.2025
Паттерны проектирования — это проверенные временем решения типовых проблем разработки программного обеспечения. Их история берёт начало с книги "Приёмы объектно-ориентированного проектирования. . . .
Исключения в C#: Stack Overflow, Access Violation и Out of memory
stackOverflow 26.04.2025
Исключения в C# — это не только механизм оповещения о проблемах, а целое искусство управления потоком выполнения программы в экстремальных ситуациях. Обычное исключение, например,. . .
Логирование в C# ASP.NET Core с помощью Serilog, ElasticSearch, Kibana
stackOverflow 25.04.2025
Помните те времена, когда для анализа проблемы приходилось подключаться к серверу, искать нужный лог-файл среди десятков других и вручную фильтровать тысячи строк в поисках ошибки? К счастью, эти дни. . .
Структура "железный OnKeyUp" вместо антидребезга. Полностью асинхронный счётчик.
Hrethgir 25.04.2025
Программа для симуляции схемы - Logisim Evolution В общем какое-то время отвлёкся, так было надо, теперь когда запилю это на verilog и FPGA , досоставлю заявку в ФИПС на полезную модель - не готов. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru