Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Другие темы раздела
Pascal типизированные файлы https://www.cyberforum.ru/ pascal/ thread314935.html
создать файл телефонный справочник. найдите номер АТС(первые две цифры номера телефона), имеющий наибольшее число абонентов.
Пересечение треугольника и окружности Pascal
На плоскости заданы множество точек и окружность радиусом R с центром в начале координат. Постройте множество всех треугольников с вершинами в заданных точках, имеющих непустое пересечение с окружностью.
Pascal ознакомиться с терой по интервальной математике и создать модуль по выполнению 4 арифметических действий(+,-,/,*) https://www.cyberforum.ru/ pascal/ thread314899.html
Ознакомиться с терой по интервальной математике и создать модуль по выполнению 4 арифметических действий(+,-,/,*).Пожалуйста помогите,мне нужно срочно!
Pascal Надо написать 2 программы, суть которых в определении количества чисел (по заданным критериям) в последовательности с неизвестным кол-вом чисел. Помогите, пожалуйста, написать две программки: 1. Программа, которая в последовательности целых чисел определяет количество чисел, кратных 5 или 7. Программа получает на вход целые числа, количество которых неизвестно. Последовательность заканчивается числом 0 (0 - признак окончания ввода, не входит в последовательность). Количество чисел не превышает 1000, сами числа по модулю не превышают 30... https://www.cyberforum.ru/ pascal/ thread314872.html
Ошибка в коде Pascal
помогите плиз Program kurs_2; Uses crt; Type mas=array of real; Var x,y:mas; Rq,Int:real; f1,f2:text; l,k,i:integer; begin clrscr;
Pascal Рекурсивная программа для вычисления функции https://www.cyberforum.ru/ pascal/ thread314567.html
Написать рекурсивную программу для вычисления
Pascal Исправить 3адачу: дана строка длиной n символов, Вывести все слова, отличные от последнего слова, предварительно удалив из слов нечетной длины его сре https://www.cyberforum.ru/ pascal/ thread314539.html
дана строка, между словами не менее одного пробела, в конце точка. Вывести все слова, отличные от последнего слова, предварительно удалив из слов нечетной длины его среднюю букву. В чем у меня может быть ошибка? Не обрабатывается последнее слово.. uses crt; var str,s2,newstr:string; i,j,n,x,k,s,w:integer;
Pascal Программирование алгоритмов циклической структуры
Помогите составить программу, проверяющую, верно ли утверждение, что введенное Вами целое число является нечетным.(с помощью цикла) Заранее спасибо..)
Pascal Создайте программу для вычисления суммы квадратов https://www.cyberforum.ru/ pascal/ thread314509.html
Создайте программу для вычисления суммы квадратов простых чисел, лежащих в интервале (M,N)
Pascal Найти значение функции https://www.cyberforum.ru/ pascal/ thread314507.html
Даны: A,B,C - массивы из 20 элементов, состоящие из случайных целых чисел от 1 до 100. Найти значение функции F1: MIN(a1,a2,...,a20)/MAX(b1,b2,...,b20), если MIN(c1,c2,...,c20)>0 MAX(a1+b2,..., a20+b20)
Pascal Матрица.Создать
Сформировать матрицу размерности 10х10 случайных натуральных чисел, значения которых не превышают 200. Выдать ее на экран. Сжать матрицу, удалив из нее все четные строки. Выдать на экран. Сжать матрицу, удалив из нее нечетные строки. Выдать ее на экран (в программе должны быть процедуры выдачи матрицы на экран и процедура удаления некоторой строки из матрицы).
Pascal Паскаль с матрицей https://www.cyberforum.ru/ pascal/ thread314505.html
Помогите пожалуйста решить,очень нужно! Если кто решит,буду очень благодарен! И если получится,напишите блок-схему. Я в паскале не бум-бум... А зачет не поставят без задачи :cry: P.S. Нижний лист сначала идет
13095 / 5876 / 1706
Регистрация: 19.09.2009
Сообщений: 8,808
07.06.2011, 17:47 0

создать стек в памяти из этих чисел таким образом, чтобы на вершине стека было самое большое число. Удалить из стека все отрицательные элементы. - Pascal - Ответ 1736140

07.06.2011, 17:47. Показов 1908. Ответов 3
Метки (Все метки)

Ответ

Pascal
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
program Project1;
 
const
  //Наибольшая глубина стека. Т. е. максимальное количество элементов,
  //которое может поместиться в стек.
  StSizeMax = 30;
 
type
  //Тип, описывающий стек.
  TStack = record
    //Указатель вершины стека. Это индекс последнего добавленного элемента.
    Pnt : Integer;
    //Контейнер данных стека.
    Data : array[1..StSizeMax] of Integer;
  end;
 
//Добавить в стек элемент.
function StackPush(var aStack : TStack; const aNum : Integer) : Boolean;
begin
  StackPush := False;
  with aStack do begin
    if Pnt < High(Data) then begin
      //Индекс добавляемого элемента.
      Inc(Pnt);
      //Добавляем элемент в массив (т. е. в стек).
      Data[Pnt] := aNum;
      StackPush := True;
    end;
  end;
end;
 
//Взять из стека элемент.
function StackPop(var aStack : TStack; var aNum : Integer) : Boolean;
begin
  StackPop := False;
  with aStack do begin
    if Pnt >= Low(Data) then begin
      aNum := Data[Pnt];
      Dec(Pnt);
      StackPop := True;
    end;
  end;
end;
 
const
  //Будем работать с M элементами стеков.
  M = 10;
 
const
  Fn = 'file.txt';
var
  F : Text;
  St1, St2 : TStack;
  i, Num1, Num2 : Integer;
begin
  Assign(F, Fn);
 
  Rewrite(F);
  Writeln('Содержимое файла:');
  Randomize;
  for i := 1 to M do begin
    Num1 := -30 + Random(101); //-30..70.
    Write(F, Num1);
    if i < M then Writeln(F);
    //Распечатка значений в окне консоли.
    if i > 1 then Write(', ');
    Write(Num1);
  end;
  Writeln;
  Flush(F);
 
  //Инициализация стеков.
  St1.Pnt := 0;
  St2.Pnt := 0;
 
  //Читаем данные из файла в первый стек и при этом "гоним пузырёк" по неубыванию
  //от дна стека - к вершине, по мере загрузки в стек значений.
  Reset(F);
  Num1 := 0;
  Num2 := 0;
  i := 0;
  while not Eof(F) do begin
    Inc(i);
    Num1 := Num2;
    Readln(F, Num2);
    if i < 2 then Continue;
    if Num1 <= Num2 then begin
      StackPush(St1, Num1);
    end else begin
      StackPush(St1, Num2);
      Num2 := Num1;
    end;
  end;
  //Дописываем в стек оставшееся число - оно и есть наибольшее из всех чисел в файле.
  if i > 0 then StackPush(St1, Num2);
 
  Close(F);
 
  //Распечатываем содержимое первого стека.
  //При этом, чтобы не потерять элементы, применяем переливание между стеками.
  Writeln('Содержимое стека после обработки данных из файла:');
  i := 0;
  while StackPop(St1, Num1) do begin
    Inc(i);
    StackPush(St2, Num1);
    if i > 1 then Write(', ');
    Write(Num1);
  end;
  Writeln;
  //Переливаем элементы обратно - из второго стека - в первый стек.
  while StackPop(St2, Num1) do StackPush(St1, Num1);
 
  //Теперь удаляем из первого стека отрицательные элементы.
  //Опять действуем через переливание.
  while StackPop(St1, Num1) do begin
    if Num1 < 0 then Continue;
    StackPush(St2, Num1)
  end;
  //Переливаем элементы обратно.
  while StackPop(St2, Num1) do StackPush(St1, Num1);
 
  //Распечатываем содержимое первого стека.
  Writeln('Содержимое стека после удаления отрицательных элементов:');
  i := 0;
  while StackPop(St1, Num1) do begin
    Inc(i);
    StackPush(St2, Num1);
    if i > 1 then Write(', ');
    Write(Num1);
  end;
  Writeln;
 
  Readln;
end.


Вернуться к обсуждению:
создать стек в памяти из этих чисел таким образом, чтобы на вершине стека было самое большое число. Удалить из стека все отрицательные элементы. Pascal
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
07.06.2011, 17:47
Готовые ответы и решения:

Структура стек (: добавить элемент в стек, удалить элемент из стека, получить значение с вершины стека, размер стека...)
Всем привет,ребят помогите пожалуйста с лабой,вообще без понятия про стеки:( Может кто то...

Стек: Переместить все элементы из первого стека во второй и вывести адрес новой вершины стека
Даны указатели P1 и P2 на вершины двух непустых стеков. Переместить все элементы из первого стека...

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

Дан указатель P1 на вершину стека (если стек пуст, то P1 = nil). Извлечь из стека все элементы и вывести их значения
Динамические структуры данных Все числа, используемые в заданиях на динамические структуры...

3
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.06.2011, 17:47
Помогаю со студенческими работами здесь

Если x равен вершине «стека», то удалить из «очереди» элемент и поместить его в «стек»
Пожалуйста, помогите решить задачу, написав ее на C#!!! Если x равен вершине «стека», то удалить из...

В стек Stek2 поместить все отрицательные элементы стека Stek1 и найти их произведение
Помогите написать программу. Описать структуры данных, процедуры и функции, необходимые для работы...

Создать два новых стека, переместив в первый из них все элементы исходного стека с четными значениями
Дан указатель P1 на вершину непустого стека. Создать два новых стека, переместив в первый из них...

Преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом - все отрицательные
Преобразовать массив таким образом, чтобы сначала располагались все положительные элементы, а потом...

0
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru