1. Заголовок темы должен быть информативным. В противном случае тема удаляется ... 2. Все тексты программ должны помещаться в теги [code=pas] ... [/code], либо быть опубликованы на нашем PasteBin в режиме вечного хранения. 3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали! 4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора). 5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM! 6. Одна тема - один вопрос (задача) 7.Проверяйте программы перед тем, как разместить их на форуме!!! 8.Спрашивайте и отвечайте четко и по существу!!!
можете малинькие программки написать чтобы понять массивы? а вот и массив
type masyvas = array [1..5] of integer;
var mas: masyvas;
i, k: integer;
мне надо узнать чему будет равняется mas[4] выполнив такое
a) for i := 1to5do
mas[i] := i;
b) k := 15;
for i := 1to5do
mas[i] := k + i;
c) for i := 5downto1do
mas[i] := i;
d) k := 1;
for i := 10to14dobegin
mas[k] := i;
k := k + 1end;
а мои ответы вот a)4 b)19 c)2 d)6 правильна а попоже исче выложу что я нипонял
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
type masyvas = array [1..5] of integer;
var mas: masyvas;
i, k: integer;
beginfor i := 5downto1dobegin
mas[i] := i;
writeln(mas[i]);
end;
readln
end.
вот что выводит на экран 5 4 3 2 1 и ответ должен быть 2 а вот и следущий чевота ниполучается но написал так d)
type masyvas = array [1..5] of integer;
var mas: masyvas;
i, k: integer;
begin
k := 1;
for i := 10to14dobegin
mas[k] := i;
k := k + 1 ;
writeln(k);
end;
readln
end.
а вот что на экране 2 3 4 5 6 и ответ 5 так в чуем неправильна
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
c)4 d)14 во сечас правильно а в проге ошибку выдает пачему
type masyvas = array [1..5] of integer;
var mas: masyvas;
i, k: integer;
begin
k := 1;
for i := 10to14dobegin
mas[k] := i;
k := k + 1 ;
writeln('mas[', i, '] = ', mas[k]);
end;
readln
end.
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
Ошибку не выдает, но ты не видишь правильных результатов. Надо печатать то же значение индекса, с которым производилось действие, ДО его увеличения:
type masyvas = array [1..5] of integer;
var mas: masyvas;
i, k: integer;
begin
k := 1;
for i := 10to14dobegin
mas[k] := i;
writeln('mas[', k, '] = ', mas[k]);
k := k + 1 ;
end;
readln
end.
const a = ...;
b = ...;
type mas = array[a..b] of integer;
procedure MinMax (m: mas;
var min, max: integer);
var k, t: integer;
begin
min := m[a]; max := m[a + 1];
for k := a + 2to b dobegin
t := m[k];
if t < min then min := t;
if t > max then max := t
end;
end;
когда m=(4, 8, 12, 3, 2, 17), то получается такие результаты min = 2, max = 17.когда m = (8, 4, 17, 3, 2, 12),резултаты такие же самие в обоих случаях правильна,но можна подобрать первичные данные чтобы результат процедуры был неправильный. подберите такие первичные данные и укажите в чом ошибка я тут нипонел как там а и b что с ними делать и куда нада ввадить ети данные
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
var t: array[1..30] of real;
seka: array[0..200] of real;
s : array[-1..0] of integer;
ss : array[-1..5] of integer;
log : array[-2..2] of boolean;
sek : array[-100..100] of real.
па моему t= 30; seka=201 ; s = 2; ss= 6; log = 5; sek = 201; провелна
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
a) function A (m: array[k..n: integer] of real): integer;
var maž: real; { Mažiausias elementas }
nr, { ir jo numeris }
i: integer;
begin
maž := m[k]; nr := k;
for i := k + 1to n doif maž > m[i]
thenbegin
maž := m[i];
nr := i
end;
A := nr
end;
b) function B (m: array[k..n: integer] of real): integer;
var maž: real; { Mažiausias elementas }
nr, { ir jo numeris }
i: integer;
begin
maž := m[n]; nr := n;
for i := n - 1downto k doif maž > m[i]
thenbegin
maž := m[i];
nr := i
end;
B := nr
end;
c) function C (m: array[k..n: integer] of real): integer;
var maž: real; { Mažiausias elementas }
nr, { ir jo numeris }
i: integer;
begin
maž := m[k]; nr := k;
for i := k + 1to n doif maž >= m[i]
thenbegin
maž := m[i];
nr := i
end;
C := nr
end;
а они эквивалентные. почему? мой ответ да они эквивалентные. a и b одинаковы толко разница в > i >= , а c обратнай а. правильно?
Сообщение отредактировано: maksimla -
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
Они НЕ эквивалентные, потому как одна из этих функций находит индекс первого вхождения минимального элемента, а еще 2 - индекс последнего вхождения. А это значит, что на одних и тех же входных данных ты получишь разные результаты, так о какой эквивалентности ты говоришь?
type diena = (vakar, šiandien, rytoj);
vektorius = array [1..30] of real;
var a: vektorius;
b: array [-2..2] of (x, y, z);
c: array ['0'..'9'] of vektorius;
d: array [diena] of0..23;
каждаму массиву a,b,c,d укажите: a) скока в нем есть элиментов; b)какие значение могут иметь элименты; c)как указать первый и последний элимент; мои ответы a) a =real, b= (x,y,z) ,c=real,d= 0..23; b)? c)?
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
a) A: 30; B: 5; C: 10; D: 3; b) A: real; B:(x, y, z); C: array of real; D: 0 .. 23; c) A[1] и A[30]; B[-2] и B[2]; C['0'] и C['9']; D[vakar] и D[rytoj]
Ты бы про систему типов что-нибудь почитал что-ли? А то вопросы - из тех, которые рассматриваются на первых страницах книг по Паскалю обычно...
P.S. Насколько же в Ada проще работа с массивами...
а ты мог бы за неделю пройти все про массивы и запись в файл самостоятельно с нуля все и ище в школи учится? может посоветуешь книгу скачать чтобы все изучать? вот исчо пару задачь
const n =...;
type masyvas = array[1..n] of integer;
procedure Tvarka(m: masyvas);
var c: integer; { Masyvo elementas }
i, k: 1..n; { Masyvo indeksai }beginfor k := 1to n – 1dofor j := 1to n – k doif m[j] > m[j + 1] thenbegin{Du elementai keičiami vietomis}
c := m[j + 1];
m[j + 1] := m[j];
m[j] := c
end;
end;
какой будет прцедуры результат (массив m значение) если перед процедурой,этот массив (точнее,массива m факта параметр) значение было 55 22 44 22, о n = 4. что выполняет эта процедура
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
я сам начал изучать pascal c 0 + школьная программа не знаю где скачать но есть хорошая книжка учебник для вузов т.а.павловская паскаль программирование на языке выс. уровня издательство "питер"
Никакой не будет - процедура не возвращает результат. Вот об этом я и говорю, ты не знаешь основ, а хочешь продвигаться дальше - будешь натыкаться на грабли постоянно...
У тебя в процедуру массив передается по значению, ты с ним можешь делать все что угодно - после выхода из процедуры он не изменится.
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.
задачу решите пожалста . сделаите програмку если выстрелить N раз. если попадет премия 2 дополнительных патрона. в фаиле tiras.txt в первай строчке написана число N. В других N строчках вписан ноль (0) если непопал, а если попал (1). если выстрел был удачный в этойже строчке о дополнителных точности выстрела. пример 5 семь выстрлов удачных 0 1 0 0 1 1 0 0 0 0 1 0 1 1 1 0 0 0 0 напишите программу каторая в фаил taikyk.txt написала скока выстрелов удачных. в программе нельзя применять eoln и eof функций вместо их пишите циклы.
следущая задача радился у отца сын и он решил откладывать деньги на свадьбу сына. первичные данные считываются с файла Pinigai.txt. В первой строчке напишите на угад когда сын женится натуральное число. скоко он будет лет собирать. каждый год откладывает деньги. пример 18 100 100 100 150 200 68 300 100 300 500 20 30 38 80 90 30 100 1000 вот ответ 3306 напишите программу скока денег собрал в фаил Ves.txt. вот сделал сам правильна
program vestuves;
var n,
a,b, i: integer;
pradDuom,
rezult: text;
begin
assign (pradDuom, 'Pinigai.TXT');
assign (rezult, 'Vest.TXT');
reset (pradDuom);
rewrite (rezult);
read (pradDuom, n);
for i := 1to n dobegin
read (pradDuom, a);
b := b + a;
end;
write (rezult, b);
close (pradDuom);
close (rezult)
end.
и последняя задача акций курс постоянна меняется. акции лутше покупать когда они дешевые а продавать когда дорогие. первичные данные - курс акций в первый день года и их изменение в массиве в каторам указываем на скока поднялась акция по сравнению с прошлым днем (от 2 до 365 года дней ). напишите а) идеи решения б) процедуру , результатам было бы два числа 1 кагда акция наивыгодней покупать 2 кагда акцию выгодней продать. пример 1 дне года акция была 155,5 а потом минялась так : Metų diena 2 3 4 5 6 7 8 9 10 11 12 13 14 Akcijų kurso pokytis 2 0,5 –1 1,5 –2 –3 –1,5 1 1,5 0,5 6 –0,5 0 значит наивыгодней покупать акции 8 дня , а продать 12 дня. первичные данные вводите в один массив каторый написан так Код const MAX = 365 type Tpokytis = array [1..MAX] of real;
первичных данных массив назовите pokytis а резултаты переменных назовите dPirkti и dParduoti. зделайте программу.
--------------------
Учусь первый год на программиста в колледже. Учусь на втором курсе в школе программирования при научно-исследовательском институте математики и информатики.