• Добро пожаловать на компьютерный форум Tehnari.ru. Здесь разбираемся с проблемами ПК и ноутбуков: Windows, драйверы, «железо», сборка и апгрейд, софт и безопасность. Форум работает много лет, сейчас он переехал на новый движок, но старые темы и аккаунты мы постарались сохранить максимально аккуратно.

    Форум не связан с магазинами и сервисами – мы ничего не продаём и не даём «рекламу под видом совета». Отвечают обычные участники и модераторы, которые следят за порядком и качеством подсказок.

    Если вы у нас впервые, загляните на страницу о форуме и правила – там коротко описано, как задать вопрос так, чтобы быстро получить ответ. Чтобы создавать темы и писать сообщения, сначала зарегистрируйтесь, а затем войдите под своим логином.

    Не знаете, с чего начать? Создайте тему с описанием проблемы – подскажем и при необходимости перенесём её в подходящий раздел.
    Задать вопрос Новые сообщения Как правильно спросить
    Если пришли по старой ссылке со старого Tehnari.ru – вы на нужном месте, просто продолжайте обсуждение.

Нужна помощь с решениями задач. Паскаль

  • Автор темы Автор темы lalka
  • Дата начала Дата начала

lalka

Новые
Регистрация
12 Фев 2014
Сообщения
12
Реакции
0
Баллы
0
Нужна помощь с решениями задач. Паскаль

№1. В одномерном массиве с четным кол-вом элементов (2N) находятся координаты N точек плоскости. Они располагаются в следующем порядке: x1, y1,x2,y2,...,xn,yn. Определить кольцо с центром в начале координат, которое содержит все точки.
№2. Создайте целочисленный массив A[1..15] с помощью генератора случайных чисел с элементами от -15 до 30 и выведите его на экран. Определите самый большой элемент массива и его индекс.
№3 Вводится строка. Определить количество слов, равный по длине первому слову.
№4 В данном слове поменять местами буквы, стоящие на p-й и q-й позициях от начала.
№5 Даны целые числа a1,a2,..,an и b1,b2,..,bn. Преобразовать последовательность b1,b2,..bn по правилу, если ai<=0 то bi увеличить в 10 раз, иначе заменить нулем.
 
Ладно. :dobriy:
№1. В одномерном массиве с четным кол-вом элементов (2N) находятся координаты N точек плоскости. Они располагаются в следующем порядке: x1, y1,x2,y2,...,xn,yn. Определить кольцо с центром в начале координат, которое содержит все точки.
Код:
Const
 N=20;
Var
 A:Array[1..2*N] of real;
 R:Array[1..N] of Real;
 Rmin,Rmax:real;
 i:byte;
Begin
 Randomize;
 for i:=1 to 2*N do A[i]:=(Random-0.5)*40;
 for i:=1 to N do R[i]:=Sqrt(Sqr(A[2*i-1])+Sqr(A[2*i]));
 Rmax:=0;
 Rmin:=100;
 for i:=1 to N do
  begin
   if R[i]<Rmin then Rmin:=R[i];
   if R[i]>Rmax then Rmax:=R[i];
  end;
 Writeln('Rmin = ',Rmin:0:3,'        Rmax = ',Rmax:0:3);
 Readln
End.
№2. Создайте целочисленный массив A[1..15] с помощью генератора случайных чисел с элементами от -15 до 30 и выведите его на экран. Определите самый большой элемент массива и его индекс.
Код:
Var
 A:Array[1..15] of Integer;
 i,Imax:byte;
 Max:Integer;
Begin
 Randomize;
 Max:=-16;
 for i:=1 to 15 do
  begin
   A[i]:=-15+Random(46);
   write(A[i]:4);
   if A[i]>Max then
    begin
     Max:=A[i];
     Imax:=i;
    end;
  end;
 writeln;
 writeln('Maximal is A[',Imax,'] = ',A[Imax]);
 Readln
End.
№3 Вводится строка. Определить количество слов, равный по длине первому слову.
http://www.tehnari.ru/f43/t96930/
№4 В данном слове поменять местами буквы, стоящие на p-й и q-й позициях от начала.
Код:
Var
 W:String;
 p,q:byte;
 Cp,Cq:Char;
Begin
 Repeat
  write('Enter the word: ');
  readln(W);
  write('p= ');
  readln(p);
  write('q= ');
  readln(q);
  if (p>Length(W)) or (q>Length(W)) or (p=q) then
   writeln('Incorrect!');
 Until (p<=Length(W)) and (q<=Length(W)) and (p<>q);
 Cp:=W[p];
 Cq:=W[q];
 Delete(W,p,1);
 Insert(Cq,W,p);
 Delete(W,q,1);
 Insert(Cp,W,q);
 writeln(W);
 Readln
End.
№5 Даны целые числа a1,a2,..,an и b1,b2,..,bn. Преобразовать последовательность b1,b2,..bn по правилу, если ai<=0 то bi увеличить в 10 раз, иначе заменить нулем.
Код:
Const
 N=16;
Var
 A,B:Array[1..N] of Integer;
 i:byte;
Begin
 Randomize;
 for i:=1 to N do
  begin
   A[i]:=-10+Random(20);
   B[i]:=Random(10)+1;
  end;
 Writeln('Before:');
 write('Array A:    ');
 for i:=1 to N do write(A[i]:4);
 writeln;
 write('Array B:    ');
 for i:=1 to N do write(B[i]:4);
 writeln;
 Writeln('After:');
 write('Array B:    ');
 for i:=1 to N do
  begin
   if A[i]<=0 then B[i]:=B[i]*10 else B[i]:=0;
   write(B[i]:4);
  end;
 Readln
End.
 
Назад
Сверху