ProgrammingFA
784 subscribers
5 photos
3 files
19 links
Все про программирование. Статьи, видео, обсуждения.

Бот - @ProgrammingFAbot
Чат - @ProgrammingFAchat
По вопросам и рекламе - @abinba
Download Telegram
Например, чтобы вывести на экран адрес ячейки памяти, на который ссылается указатель b во втором примере, мы пишем cout << "Address of b is " << &b << endl;. В моей системе, я получил значение 0x1aba030. У вас оно может быть другим, потому что адреса в оперативной памяти распределяются таким образом, чтобы максимально уменьшить фрагментацию. Поскольку, в любой системе список запущенных процессов, а также объем и разрядность памяти могут отличаться, система сама распределяет данные для обеспечения минимальной фрагментации.

Для того, чтобы получить значение, которое находится по адресу, на который ссылается указатель, используется префикс *. Данная операция называется разыменованием указателя.

Во втором примере мы выводим на экран значение, которое находится в ячейке памяти (у меня это 0x1aba030): cout << "b is " << *b << endl; . В этом случае необходимо использовать знак *.

Чтобы изменить значение, находящееся по адресу, на который ссылается указатель, нужно также использовать звездочку, например, как во втором примере — *b = *a + *b;.

- Когда мы оперируем данными, то используем знак *

- Когда мы оперируем адресами, то используем знак &

В этих вещах очень часто возникают недопонимания, и кстати, не только у новичков. Многие из тех, кто начинал программировать с того же php, также часто испытывают подобную путаницу при работе с памятью.

Для того, чтобы освободить память, выделенную оператором new, используется оператор delete.

При использовании оператора delete для указателя, знак * не используется.
Домашняя работа

1)
Реализовать функцию которая выводит строку в обрятном порядке, пример "hello" -> "olleh". Oбъявление функции которую нужно реализовать:
void str_rev(char* str);

2) Объявите указатель на массив типа double и предложите пользователю выбрать его размер. Далее напишите четыре функции: первая должна выделить память для массива, вторая – заполнить ячейки данными, третья – показать данные на экран, четвертая – освободить занимаемую память. Программа должна предлагать пользователю продолжать работу (создавать новые динамические массивы ) или выйти из программы.

3) Объявить и заполнить двумерный динамический массив случайными числами от 10 до 50. Показать его на экран. Для заполнения и показа на экран написать отдельные функции. (подсказка: функции должны принимать три параметра – указатель на динамический массив, количество строк, количество столбцов). Количество строк и столбцов выбирает пользователь.

Присылайте домашнее задание в наш чат @ProgrammingFAchat
Грядет перезагрузка!

Мы, долго думая, решили перезапустить канал с новым контентом. Исходя из того, что очень много людей писали с просьбой сделать контент про Python, именно он и станет главной темой этого канала. Также мы планируем добавить новые интересные рубрики, которые будут покрывать самые различные темы в сфере программирования и не только.
Оставайтесь с нами!
Свой вариант предлагайте в нашем чате:

@ProgrammingFAchat
Python!

Язык Python
является, пожалуй, самым простым в изучении и самым приятным в использовании из языков программирования, получивших широкое распространение. Программный код на языке Python легко читать и писать, и, будучи лаконичным, он не выглядит загадочным.

Python - очень выразительный язык, позволяющий уместить приложение в меньшее количество строк, чем на это потребовалось бы в других языках, таких как C++ или Java.

Python является кросс-платформенным языком: обычно одна и та же программа на языке Python может запускаться и в Windows, и в UNIX-подобных системах, таких как Linux, BSD и Mac OS, для чего достаточно просто скопировать файл или файлы, составляющие программу, на нужный компьютер; при этом даже не потребуется выполнять «сборку», или компилирование программы. Конечно, можно написать на языке Python программу, которая будет использовать некоторые характерные особенности конкретной операционной системы, но такая необходимость возникает крайне редко, т. к. практически вся стандартная библиотека языка Python и большинство библиотек сторонних производителей обеспечивают полную кросс-платформенность.

Одним из основных преимуществ языка Python является наличие полной стандартной библиотеки, позволяющей обеспечить загрузку файла из Интернета, распаковку архива или создание веб-сервера посредством написания нескольких строк программного кода. В дополнение к ней существуют тысячи дополнительных библиотек сторонних производителей, среди которых одни обеспечивают более сложные и более мощные возможности, чем стандартная - например, библиотека для организации сетевых взаимодействий Twisted и библиотека для решения вычислительных задач NumPy; а другие предоставляют функциональность, которая слишком узконаправленно специализирована, чтобы ее можно было включить в стандартную библиотеку - например, пакет моделирования SimPy.

Python может использоваться для программирования в процедурном, в объектно-ориентированном и, в меньшей степени, в функциональном стиле программирования, хотя в глубине души Python - объектно-ориентированный язык программирования.

Применение Python

Существует множество областей применения Python, но в некоторых он особенно хорош. Таким образом, можно выделить 4 самых популярных направления применения Python:

- веб-разработка;
- data science: анализ данных и визуализация;
- машинное обучение;
- автоматизация процессов.

Кому интересно, подробнее о применении Python читайте здесь:
https://proglib.io/p/python-applications/

Обсуждаем пройденное в чате:
@ProgrammingFAchat
А сегодня мы установим интерпретатор Python и попробуем написать нашу первую программу.

Windows:
Скачивать Python для Windows будем с официального сайта:
https://www.python.org/downloads/windows/

Под заголовком страницы следуют 2 ссылки - последний стабильный релиз для python2 и python3. Этот курс включает в себя изучение python3, именно третьей версии, не второй. Следовательно, мы и выбираем её.

После перехода по ссылке скачайте:
- Windows x86-64 executable installer (если у вас 64-разрядная система);
- Windows x86 executable installer (если система 32-разрядная).

После скачивания файла, запустите его и следуйте инструкциям установщика.
IDLE Python3 доступно теперь из пуска windows!

* IDLE (Integrated Development and Learning Environment) — это интегрированная среда разработки и обучения на языке Python.

Linux:
Для пользователей linux вся установка сводится к установке пакета python3.
Для ubuntu/debian:
apt install python3
Для arch:
pacman -S python3
Для centOS:
yum install epel-release python36

MacOS:
Как и для linux, установка одной командой:
brew install python3

Написание первой программы

Пользователи Windows открывают Python3 IDLE из меню Пуск, а пользователи linux и macOS вводят в терминале
python3
И после приглашения к вводу:
>>>
Введите следующий текст и нажмите Enter:
print("Hello, world!")

Hello, world!

😱🎉🎊

Поздравляю! Только что Вы написали свою первую программу на Python3!

Поделитесь
первой программой в чате:
@ProgrammingFAchat
Мы хотели бы оценить средний уровень знаний нашей аудитории. Это поможет нам создавать более качественный контент для Вас
Anonymous Poll
65%
Я начинающий
29%
Я любитель
6%
Я продвинутый
0%
Свой вариант в чате
Так что же такое интерпретация?

Интерпретация — построчный анализ, обработка и выполнение исходного кода программы или запроса (в отличие от компиляции, где весь текст программы, перед запуском, анализируется и транслируется в машинный или байт-код, без её выполнения).

Хорошо, поняли. Что дальше?

Дальше есть два способа запуска своих програм и первый из них - писать в самом IDLE, либо использую команду:

Windows:
py <путь к файлу с кодом>
Например, ваша программа находится в диске D:
py D:\my_code.py

Linux:
python3 <путь к файлу с кодом>

Mac:
python <путь к файлу с кодом>

Мы разобрались с запуском программы, теперь изучим простейшие математические операции, которые возможно применять в Python.

Как мы поняли из предыдущего урока, print() это функция Python, которая отвечает за вывод заданного аргумента на консоль.

Функция - это определнный фрагмент кода, который имеет идентификатор или имя и к которому можно обратиться из другого места программы.

Аргумент - это то, что мы передаем в функцию для выполнения определенных операций. И в следующей строке:

print("I love Python")

Строка "I love Python" является аргументом, переданным в функцию print().

По умолчанию print() переносит каждый раз курсор консоли на новую строку и чтобы избежать этого вы можете определить аргумент end, как пустой.

print("I love Python", end='')
print(", but I hate PHP")
Результат: I love Python, but I hate PHP

Аргументом функции print() может быть не только строка.

print(5+5)
Вывод: 10
print(6*7)
Вывод: 42
print(30-2)
Вывод: 28
print(10/2)
Вывод: 5
print(2**4)
Вывод: 16

И так далее. Таким образом, у вас есть возможность выполнять любые математические операции.
#sammelsurium

По итогам голосования ~40% аудитории этого канала уже не новички, а потому, чтобы скрасить ваше ожидание нового и полезного материала по основной тематике канала, вводится рубрика #sammelsurium, где будет выкладываться всякая интересная и полезная всячина

А сегодня мы познакомися с бесподобной Джулией Эванс. Ее книжки видел каждый из вас хоть раз в жизни. Автор комиксов, пособий, мемов, а так же специалист высшего класса. Под постом я опубликую одну из ее книженций, а перейдя по ссылке (https://firstvds.ru/blog/julia_evans), можно ознакомиться со всем переведенным на русский язык творчеством
В этом уроке мы ознакомимся с типами данных, переменнами и функцией ввода данных.

Что такое переменная?
Переменная - поименованная, либо адресуемая иным способом область памяти, адрес которой можно использовать для осуществления доступа к данным. Данные, находящиеся в переменной (то есть по данному адресу памяти), называются значением этой переменной.

Допустим, у нас есть код:
number = 5

Для того, чтобы объявить и сразу инициализировать переменную необходимо написать её имя, потом поставить знак равенства и значение, с которым эта переменная будет создана, что мы и сделали. Мы объявили переменную с именем number и присвили ей значение целого числа 5.

Целочисленное значение 5 в рамках языка Python по сути своей является объектом. Объект, в данном случае – это абстракция для представления данных, данные – это числа, строки и т.п. Каждый объект имеет три атрибута – это идентификатор, значение и тип. Идентификатор – это уникальный признак объекта, позволяющий отличать объекты друг от друга, а значение – непосредственно информация, хранящаяся в памяти, которой управляет интерпретатор.

Таким образом, переменные могут быть разных типов, в зависимости от типа её значения, например:

- Логические переменные (Boolean Type)
Принимает значение True (истина) или False (ложь).

- Числовой тип (Numeric Type)
Числовой тип, в свою очередь также делится на следующие типы:
int (integer) – целое число
float – число с плавающей точкой
complex – комплексное число

- Строки (Text Sequence Type) - str (string)

Это основные типы данных, которые мы будем использовать на первых уроках, остальные же будем осваивать по ходу материала.

Имя переменной не должно совпадать с ключевыми словами интерпретатора Python. Список ключевых слов можно найти здесь.

Тип переменной можно определить с помощью функции type(). Например:

>>> a = 10
>>> b = "hello"
>>> type(a)
<class 'int'>
>>> type(b)
<class 'str'>

Мы уже знаем, что для вывода данных в Python используется функция print(). А для ввода данных в программу используется функция input(). Функция input() передает введенные данные в программу. Их можно присвоить переменной. Например:

print("Write your name:")
a = input()
print("Hello, " + a + "!")

Тут знаками "+" мы объединяем строки. Функции со строками мы также пройдем на следующих уроках.

Вывод:
>>> Write your name:
>>> abinba
>>> Hello, abinba!

Однако, при попытке ввести число и проводить с ней арифметические действия, мы получаем ошибку TypeError. Дело в том, что по умолчания функция input() присваивает значение типа str (то есть, строки). Если мы хотим, чтобы функция input() присваивало целочисленное значение мы должны использовать функцию int() (чтобы получить число с плавающей точкой - float()). Она конвертирует переменную в целочисленный тип. Тогда наш код будет выглядеть так:

a = int(input())
b = int(input())
sum = a + b
print("Sum = " + str(sum))

Мы конвертируем переменную sum в тип str, потому что переменная sum - типа int и не может быть добавлена к концу нашей строки в функции print().

И мы получим:
>>> 5
>>> 8
>>> Sum = 13
Домашняя работа
Создайте программы, которые:
- Будет вычислять квадрат введеного вами числа

- Будет запрашивать у вас ФИО, телефон, адрес и суммировать это в конце.

- Дайте свободу своей фантазии и сделайте произольную программу по пройденным темам.

С результатом поделитесь в нашем чате. Код в чат не отправлять, только админам!
#sammelsurium

Компьютер размером с мяч для тенниса? Для Клингера Пауля нет ничего невозможного! Основа системы - микроконтроллер ATtiny1614 с подключенным к нему OLED дисплеем с разрешением 128 × 64 пикселя. Все это спрятано в корпус, напечатанный на 3D-принтере. Уже не терпится взглянуть? Ниже привожу ссылку на репозиторий Пауля, где имеется весь исходный код проекта на С и ассемблере. Интересно, кто-нибудь решится повторить?
https://github.com/PaulKlinger/tinypc
Этот урок будет посвящен операциям со строками и логическим выражениям и сравнениям.

Базовые операции со строками:

- Конкатенация (сложение)
>>> S1 = 'spam'
>>> S2 = 'eggs'
>>> print(S1 + S2)
spameggs

- Дублирование строки
>>> print('spam' * 3)
spamspamspam

- Длина строки (функция len)
>>> len('spam')
4

- Доступ по индексу
>>> S = 'spam'
>>> S[0]
's'
>>> S[2]
'a'

- Извлечение среза
>>> s = 'spameggs'
>>> s[3:5]
'me'
>>> s[:6]
'spameg'
>>> s[1:]
'pameggs'
>>> s[:]
'spameggs'

Логические выражения и сравнения

В программировании False обычно приравнивают к нулю, а True – к единице. Чтобы в этом убедиться, можно преобразовать булево значение к целочисленному типу:

>>> int(True)
1
>>> int(False)
0

Говоря на естественном языке (например, русском) мы обозначаем сравнения словами "равно", "больше", "меньше". В языках программирования используются специальные знаки, подобные тем, которые используются в математике: > (больше), < (меньше), >= (больше или равно), <= (меньше или равно), == (равно), != (не равно).

Не путайте операцию присваивания значения переменной, обозначаемую в языке Python одиночным знаком "равно", и операцию сравнения (два знака "равно"). Присваивание и сравнение – разные операции.

>>> a = 10
>>> b = 5
>>> a + b > 14
True
>>> a < 14 - b
False
>>> a <= b + 5
True
>>> a != b
True
>>> a == b
False

На практике нередко возникает необходимость в более сложных выражениях. Может понадобиться получить ответа "Да" или "Нет" в зависимости от результата выполнения двух простых выражений. Например, "на улице идет снег или дождь", "переменная news больше 12 и меньше 20".

В таких случаях используются специальные операторы, объединяющие два и более простых логических выражения. Широко используются два оператора – так называемые логические И (and) и ИЛИ (or).

Чтобы получить True при использовании оператора and, необходимо, чтобы результаты обоих простых выражений, которые связывает данный оператор, были истинными. Если хотя бы в одном случае результатом будет False, то и все сложное выражение будет ложным.

Чтобы получить True при использовании оператора or, необходимо, чтобы результат хотя бы одного простого выражения, входящего в состав сложного, был истинным. В случае оператора or сложное выражение становится ложным лишь тогда, когда ложны оба составляющие его простые выражения.

Допустим, переменной x было присвоено значение 8 (x = 8), переменной y присвоили 13 (y = 13). Логическое выражение y < 15 and x > 8 будет выполняться следующим образом. Сначала выполнится выражение y < 15. Его результатом будет True. Затем выполнится выражение x > 8. Его результатом будет False. Далее выражение сведется к True and False, что вернет False.

>>> x = 8
>>> y = 13
>>> y < 15 and x > 8
False

В языке Python есть еще унарный логический оператор not, т. е. отрицание. Он превращает правду в ложь, а ложь в правду. Унарный он потому, что применяется к одному выражению, стоящему после него, а не справа и слева от него как в случае бинарных and и or.

>>> not y < 15
False

Также можно построить сравнение таким образом:

>>> 5 < y <= 6
False
Домашняя работа

1) Напишите программу, которая запрашивала бы у пользователя два числа и выводила бы True или False в зависимости от того, больше первое число второго или нет.

2) Есть два слова: "Spy", "Telethon". Используя только эти две строки и операции со строками, составьте слово "python".

3) Составьте программу, которая будет запрашивать любое слово и число n - количество повторений этого слова. Программа должна вывести это слово n раз.

4) Даны параметры квадратного уравнения (a, b, c) и координаты точки (x, y). Принадлежит ли точка параболе?

5) Даны координаты точки (x, y) и координаты точек пересечения трех прямых, образующих треугольник. Входит ли точка в область получившегося треугольника?
#sammelsurium

На днях меня очень заинтересовала статья на хабре о хренении вещественных чисел в памяти компьютера и их о работке, где был подробно рассмотрен метод Unum, разработанный математиком Джоном Густавсоном. По некоторым данным, метод превосходит по производительности классический IEEE 754, а так же поддерживает дополненный набор операций. Подробней ознакомиться с материалом можно по ссылкам:
https://habr.com/ru/post/462385
https://en.wikipedia.org/wiki/Unum_%28number_format%29
#sammelsurium

Маленький бонус: понятная и красочная презентация по Unum на английском языке