вот основное
Объяснение:
Середина 50-х гг. характеризуется стремительным прогрессом в области программирования. Роль программирования в машинных кодах стала уменьшаться, стали появляться языки программирования нового типа, выступающие в роли посредника между машинами и программистами. Наступило время второго и третьего поколений языков программирования.
С середины 50-х г. XX в. начали создавать первые языки программирования высокого уровня (high-level programming languages). Эти языки не были привязаны к определенному типу ЭВМ (машинонезависимы). Для каждого из них были разработаны собственные компиляторы. Компиляция — трансляция программы, составленной на исходном языке высокого уровня, в эквивалентную программу на низкоуровневом языке, близком машинному коду (абсолютный код, объектный модуль, иногда язык ассемблера).
Достоинства языков программирования высокого уровня:
Алфавит языка значительно шире машинного, что делает его гораздо более выразительным и существенно повышает наглядность и понятность текста;
Набор операций, допустимых для использования, не зависит от набора машинных операций, а выбирается из соображений удобства формулирования алгоритмов решения задач определенного класса;
Конструкции операторов задаются в удобном для человека виде;
Поддерживается широкий набор типов данных.
Недостатком языков высокого уровня является больший размер программ по сравнению с программами на языке низкого уровня. Поэтому в основном языки высокого уровня используются для разработок программного обеспечения компьютеров и устройств, которые имеют большой объем памяти. А разные подвиды ассемблера применяются для программирования других устройств, где критичным является размер программы.
Неизвестно, насколько бы ускорилось развитие программирования, если бы наработки Цузе стали доступны другим учёным в конце 40-х годов, но на практике с развитием компьютерной техники сначала получил распространение машинный язык. С его программист мог задавать команды, оперируя с ячейками памяти, полностью используя возможности машины. Суть этого языка — набор кодов, обязательно понятных процессору, к которому обращаются. Части («слова») этого языка называются инструкциями, каждая из которых представляет собой одно элементарное действие для центрального процессора, как, например, считывание информации из ячейки памяти. Лишь при понимании устройства компьютерного оборудования и знания этих целочисленных кодов можно было непосредственно управлять процессором. Тогда ещё компьютеры были простыми вычислительными машинами, применяемыми для различных математических расчётов. Но они развивались, а использование большинства компьютеров на уровне машинного языка затруднительно, особенно сложным было чтение и модификация подобных программ, что усугублялось использованием абсолютной адресации памяти[3]. Поэтому со временем от использования машинных кодов пришлось отказаться.
Например, для организации чтения блока данных с гибкого диска программист может использовать 16 различных команд, каждая из которых требует 13 параметров, таких как номер блока на диске, номер сектора на дорожке и т. п. Когда выполнение операции с диском завершается, контроллер возвращает 23 значения, отражающие наличие и типы ошибок, которые необходимо анализировать. Уже одно обращение к процессору громоздко, а анализ ошибок и вовсе представляется невообразимым, особенно, если не именно с этим процессором приходиться работать. Таким образом, набор команд машинного языка сильно зависит от типа процессора.
Поделитесь своими знаниями, ответьте на вопрос:
Авто устройство перекодировка сообщения из Unicode в CON-8 после этого объем сообщения стал 2-4 байта, сколько бит было? Решение.
1. Создайте переменную `min_element`, и присвойте ей значение первого элемента массива `x`. Также создайте переменную `min_index`, и присвойте ей значение 0 (индекс первого элемента массива).
2. Пройдитесь по оставшимся элементам массива `x`, начиная с индекса 1. Если значение текущего элемента меньше значения `min_element`, то обновите `min_element` на значение текущего элемента и `min_index` на индекс текущего элемента.
3. Вставьте число `К` перед минимальным элементом, используя `min_index`. Для этого сдвиньте все элементы массива начиная от `min_index` на одну позицию вправо.
4. Присвойте значение `К` элементу массива с индексом `min_index`.
5. Готово! Массив `x` теперь содержит число `К`, вставленное перед минимальным элементом.
Вот блок-схема алгоритма решения:
```
+---------------------------------+
| |
+-----> |
| | min_element = x[0] |
| | min_index = 0 |
| | |
| v |
| +-----------------------+ |
| | | |
| | for i = 1 to n-1 | |
+---+ +<-------+ |
| if x[i] < min_element | | |
| then | | |
| min_element = x[i] | | |
| min_index = i | | |
| end if | | |
| | | |
+------------+--------------+ | |
| | |
v | |
+------+ | |
| Swap | | |
+---+--+ | |
| | |
v | |
+--------------+ | |
| | | |
| Insert K | | |
| | | |
+--------------+ | |
| | |
v | |
+----+ | |
|End | | |
+----+ | |
| |
+------------------------------+ |
| |
| Updated x |
| |
+---------------------------------+
```
Если у вас возникнут дополнительные вопросы или что-то будет непонятно, пожалуйста, сообщите мне.