Технический форум

Технический форум (http://www.tehnari.ru/)
-   Delphi, Kylix and Pascal (http://www.tehnari.ru/f43/)
-   -   Проверьте, пожалуйста, программу. Паскаль (http://www.tehnari.ru/f43/t85178/)

tane 14.02.2013 01:46

Проверьте, пожалуйста, программу. Паскаль
 
Задача:
сведения об автомобиле состоят из его марки, номера, цвета, фамилии владельца.Подсчитать количество автомобилей заданной марки.

type vedomost=record
marka:string;
nomer:integer;
color:string;
familia:string;
end;
var
danue:array[1..3] of vedomost;
i,m:integer;
k:string;

begin
for i:=1 to 3 do
with danue[i] do
begin
writeln('Марка-'); readln(marka);
writeln('Номер-'); readln(nomer);
writeln('Цвет-');readln(color);
writeln('Фамилия-');readln(familia);
end;

writeln('Марка машины для подсчета');readln(k);
for i:=1 to 3 do
begin
with danue[i] do
if marka=k then
begin
writeln(marka);
end;
end;
readln;
end.

Debianer 14.02.2013 15:33

Данные надо вводить или уже есть? И что за дебилизм с "for i:=1 to 3 do"??? Это в смысле, если ты вводишь, то не более трех машинок? А 100? А 101?
Замечание:
Сударь, а без хамства и нарочито оскорбительно-пренебрежительного тона никак? Просто объяснить начинающему, подсказать, поправить, помочь? Или самоутверждаемся? Ну что же - получите замечание. В качестве первого предупреждения.

Модератор.

Vladimir_S 14.02.2013 19:43

Цитата:

Сообщение от Debianer (Сообщение 865257)
Данные надо вводить или уже есть?

"Имеющий глаза да увидит"... Если бы Вы дали себе труд внимательно посмотреть код, вместо того, чтобы демонстрировать, какой Вы крутой программист, то, вне всякого сомнения, узрели бы блок ввода данных и тогда отпала бы нужда в данном вопросе.

Vladimir_S 14.02.2013 20:02

Цитата:

Сообщение от tane (Сообщение 865050)
Проверьте пожалуйста программу, Паскаль

В целом правильно и грамотно, но несколько замечаний.
1. Несмотря на недопустимо-хамский тон, по сути Debianer прав в том смысле, что полное число машин лучше задать в виде константы, которую легко можно менять при желании.
2. Подсказки при вводе лучше давать без перевода строки и с пробелом в конце. Красивее.
3. В задании требуется подсчитать количество машин данной марки, а не выводить несколько раз название этой марки.
4. Если оператор (в частности, if..then) действует на ОДИН операнд, то операторные скобки begin..end ставить не обязательно. Можно, но не нужно.

Итого, с учетом сказанного:

Код:

const
 N=3;

type 
 vedomost=record
          marka:string;
          nomer:integer;
          color:string;
          familia:string;
          end;

var
  danue:array[1..N] of vedomost;
  i,m,Q:integer;
  k:string;

begin
 for i:=1 to N do
  with danue[i] do
  begin
    write('Марка - ');
    readln(marka);
    write('Номер - ');
    readln(nomer);
    write('Цвет - ');
    readln(color);
    write('Фамилия - ');
    readln(familia);
  end;
 
 writeln;
 write('Марка машины для подсчета - ');
 readln(k);

 Q:=0;
 for i:=1 to N do
  if danue[i].marka=k then Inc(Q);
 writeln(Q,' машин');
 readln;
end.

Извините, не тестировал. Вы уж сами.

Debianer 19.02.2013 03:42

За тон прошу прощения, погорячился

Debianer 19.02.2013 08:28

И еще один совет: не задавайте границы массива, лучше воспользуйтесь динамическим. Насколько я помню, в турбопаскале динамических массивов не было, вместо них использовали списки.
Погуглив, нарыл достаточно информации по этому. Просто при использовании динамического массива вы отвязываетесь от предельного размера данных, т.е. можно ввести и три машинки, и 133. Организовать данную работу можно через указатели и GetMem. Считаю, что так будет наиболее правильно, жизненно и соответствовать условиям задачи.
ЗЫ: да, код болучится более сложным

Debianer 19.02.2013 08:31

Цитата:

Сообщение от Vladimir_S (Сообщение 865339)
"Имеющий глаза да увидит"... Если бы Вы дали себе труд внимательно посмотреть код, вместо того, чтобы демонстрировать, какой Вы крутой программист, то, вне всякого сомнения, узрели бы блок ввода данных и тогда отпала бы нужда в данном вопросе.

Код я посмотрел. Вопрос про ввод данных возник не из кода, а из условия задачи - там неявно, вводятся ли данные, берутся они из файла, потока, базы данных... Отсюда и вопрос возник, нужен ли ввод или нет


Часовой пояс GMT +4, время: 21:16.

Powered by vBulletin® Version 4.5.3
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.