IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения.
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

> Задания по массивам, Помогите, плиз!
сообщение
Сообщение #1


Гость






Надо выполнить 2 задания. Помогите, пожалуйста.:

1. Поменять местами первый символ ‘А’ и последний символ ‘Y’, полученный массив вывести на экран дисплея.

2. Найти наибольший и наименьший элементы матрицы и поменять их местами.

Заранее, спасибо.
 К началу страницы 
+ Ответить 
 
 Ответить  Открыть новую тему 
Ответов(1 - 4)
сообщение
Сообщение #2


Знаток
****

Группа: Пользователи
Сообщений: 419
Пол: Мужской

Репутация: -  6  +


i := 1;
while a[i] <> 'A' do inc(i);


после выполнения i -- номер в массиве где А встречается первый раз. Остальное аналогично.


--------------------
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #3


Новичок
*

Группа: Пользователи
Сообщений: 48
Пол: Мужской
Реальное имя: Fang

Репутация: -  2  +


Ко 2-ой задаче:

Код
uses
 crt;
var
 a: array[1..10] of integer;
 pos_max, pos_min,max,min,i,temp: integer;
begin
 ClrScr;
 randomize;
 for i:=1 to 10 do
   a[i]:=random(10);
 for i:=1 to 10 do
   write(a[i], '  ');
 writeln;
 {find max}
 max:=a[1];
 pos_max:=1;
 for i:=1 to 10 do
   begin
     if a[i] > max then
       begin
         max:=a[i];
         pos_max:=i;
       end;
   end;
 {find min}
 min:=a[1];
 pos_min:=1;
 for i:=1 to 10 do
   begin
     if a[i] < min then
       begin
         min:=a[i];
         pos_min:=i;
       end;
   end;
 {min - max}
 temp:=a[pos_min];
 a[pos_min]:=a[pos_max];
 a[pos_max]:=temp;

 for i:=1 to 10 do
   write(a[i], '  ');
 readln;
end.


Правда это решение для одномерного массива, алгоритм такой:
1. Заполняем массив случ. числами
2. Выводим его
3. Ищем максимальный эл-т и запоминаем его позицию.
4. Ищем минимальный эл-т и запоминаем его позицию.
5. Меняем местами мин. и макс.

Для двумерного массива (матрицы) попробуй сделать сам.
Тем более, что делается аналогично.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #4


Perl. Just code it!
******

Группа: Пользователи
Сообщений: 4 100
Пол: Мужской
Реальное имя: Андрей

Репутация: -  44  +


Fang, а зачем ты кроме индексов максимального и минимального значения хранишь и сами эти значения ? Этого в задании вроде не требуется ...


--------------------
perl -e 'print for (map{chr(hex)}("4861707079204E6577205965617221"=~/(.{2})/g)), "\n";'
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
сообщение
Сообщение #5


Новичок
*

Группа: Пользователи
Сообщений: 17
Пол: Мужской
Реальное имя: Александр

Репутация: -  0  +


вот тебе наглядный пример как поменять элементы в двумерном массиве

for i:=1 to k do
for j:=1 to k do begin
.........
p:=a[i+1,j]; a[i+1,j]:=a[i,j]; a[i,j]:=p;
end;



М
Точно также сделал и Fang в своей программе ... флудим?
klem4

 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 





- Текстовая версия 27.05.2024 23:09
500Gb HDD, 6Gb RAM, 2 Cores, 7 EUR в месяц — такие хостинги правда бывают
Связь с администрацией: bu_gen в домене octagram.name