1

(11 відповідей, залишених у C/C++)

Q-bart написав:

але я самому таке зробити і як бути в реальному житті - мовчок

Чого мовчки ? Код досить зрозуміло прокоментований, а що роблять функції (та ін.) можна пошукати в інтернеті. Я вирізав тільки той код що відповідає за отримання цілочисельного значення.

/**
* Our own data type for string variables.
*/
typedef char *string;
#include <stdarg.h>
#include <string.h>
#include <limits.h>
#include <ctype.h>
#include <stdlib.h>
#include <stdio.h>
#include <stdlib.h>

/**
* Number of strings allocated by get_string.
*/
static size_t allocations = 0;

/**
* Array of strings allocated by get_string.
*/
static string *strings = NULL;

/**
* Prompts user for a line of text from standard input and returns
* it as a string (char *), sans trailing line ending. Supports
* CR (\r), LF (\n), and CRLF (\r\n) as line endings. If user
* inputs only a line ending, returns "", not NULL. Returns NULL
* upon error or no input whatsoever (i.e., just EOF). Stores string
* on heap, but library's destructor frees memory on program's exit.
*/
string get_string(va_list *args, const string format, ...)
{

    // check whether we have room for another string
    if (allocations * sizeof(string) == SIZE_MAX)
    {
        return NULL;
    }

    // growable buffer for characters
    string buffer = NULL;

    // capacity of buffer
    size_t capacity = 0;

    // number of characters actually in buffer
    size_t size = 0;

    // character read or EOF
    int c;

    // prompt user
    if (format != NULL)
    {
        // initialize variadic argument list
        va_list ap;

        /** Student code will pass in printf-like arguments as variadic
        *  parameters. The student-facing get_string macro always sets args to
        *  NULL. In this case, we initialize the list of variadic parameters
        *  the standard way with va_start.
        */
        if (args == NULL)
        {
            va_start(ap, format);
        }
        /** When functions in this library call get_string they will have
        *  already stored their variadic parameters in a `va_list` and so they
        *  just pass that in by pointer.
        */
        else
        {
            // put a copy of argument list in ap so it is not consumed by vprintf
            va_copy(ap, *args);
        }
        // print prompt
        vprintf(format, ap);
        // cleanup argument list
        va_end(ap);
    }

    // iteratively get characters from standard input, checking for CR (Mac OS), LF (Linux), and CRLF (Windows)
    while ((c = fgetc(stdin)) != '\r' && c != '\n' && c != EOF)
    {
        // grow buffer if necessary
        if (size + 1 > capacity)
        {
            // initialize capacity to 16 (as reasonable for most inputs) and double thereafter
            if (capacity == 0)
            {
                capacity = 16;
            }
            else if (capacity <= (SIZE_MAX / 2))
            {
                capacity *= 2;
            }
            else if (capacity < SIZE_MAX)
            {
                capacity = SIZE_MAX;
            }
            else
            {
                free(buffer);
                return NULL;
            }

            // extend buffer's capacity
            string temp = (string)realloc(buffer, capacity);
            if (temp == NULL)
            {
                free(buffer);
                return NULL;
            }
            buffer = temp;
        }

        // append current character to buffer
        buffer[size++] = c;
    }

    // check whether user provided no input
    if (size == 0 && c == EOF)
    {
        return NULL;
    }

    // check whether user provided too much input (leaving no room for trailing NUL)
    if (size == SIZE_MAX)
    {
        free(buffer);
        return NULL;
    }

    // if last character read was CR, try to read LF as well
    if (c == '\r' && (c = fgetc(stdin)) != '\n')
    {
        // return NULL if character can't be pushed back onto standard input
        if (c != EOF && ungetc(c, stdin) == EOF)
        {
            free(buffer);
            return NULL;
        }
    }

    // minimize buffer
    string s = (string)realloc(buffer, size + 1);
    if (s == NULL)
    {
        free(buffer);
        return NULL;
    }

    // terminate string
    s[size] = '\0';

    // resize array so as to append string
    string *tmp = (string*)realloc(strings, sizeof(string) * (allocations + 1));
    if (tmp == NULL)
    {
        free(s);
        return NULL;
    }
    strings = tmp;

    // append string to array
    strings[allocations] = s;
    allocations++;

    // return string
    return s;
}

/***********************************************************************************************************************/

/**
* Prompts user for a line of text from standard input and returns the
* equivalent int; if text does not represent an int in [-2^31, 2^31 - 1)
* or would cause underflow or overflow, user is prompted to retry. If line
* can't be read, returns INT_MAX.
*/
int get_int(const string format, ...)
{
    va_list ap;
    va_start(ap, format);
    // try to get an int from user
    while (true)
    {
        // get line of text, returning INT_MAX on failure
        string line = get_string(&ap, format);
        if (line == NULL)
        {
            va_end(ap);
            return INT_MAX;
        }

        // return an int if only an int (in range) was provided
        if (strlen(line) > 0 && !isspace((unsigned char)line[0]))
        {
            char *tail;
            errno = 0;
            long n = strtol(line, &tail, 10);
            if (errno == 0 && *tail == '\0' && n >= INT_MIN && n < INT_MAX)
            {
                va_end(ap);
                return n;
            }
        }

        // temporarily here for backwards compatibility
        if (format == NULL)
        {
            printf("Retry: ");
        }
    }
}
int GetInt(void)
{
    return get_int(NULL);
}

int main()
{
    int height;

    height = GetInt();

    printf("number(int) = %i, after while", height);

    //pause
    getchar();
    return 0;
}

Я підозрюю що ви можете не знати що це

int get_int(const string format, ...)

таке. Подивіться тут http://www.cplusplus.com/reference/cstdarg/

Код має багато перевірок (та іт.) які зроблені "на всякий випадок", тому потрібно звернути увагу на таке
Рядки 83 - 119 - тут йде збільшення буферу (тобто рядок можна вводити "будь якої довжини")
Рядки 201-202 - перевірки чи це інт
Якщо все пройшло успішно то strtol повертає long int число, якщо ні то в tail записується наступні символи після числа (якого немає), тобто якщо було введено "qjd" то функція "запише" в tail рядок "qjd", перевіривши рядок на пустоту (*tail == '\0') можна зробити висновок, якщо рядок пустий - функція виконана успішно, якщо рядок не пустий - функція "не виконана успішно"

2

(10 відповідей, залишених у PHP)

Я вже зрозумів, тут якраз в підключені справа... завтра напишу докладніше

3

(10 відповідей, залишених у PHP)

В мене є

  • header.php

  • index.php

  • footer.php

  • style.css

Я хочу вивести на екран (як результат) горизонтальну смугу, вміст і знову горизонтальну смугу. В якості смуги я використовую зображення, і за допомогою CSS стилів це все розміщую
CSS

.flex-container {
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: center;
    justify-content: center;
}

.flex-item {
    margin: 0px;
}

Я не став скидати весь код, там в мене з'єднання з БД, повно HTML елементів і т.д., просто для прикладу написав як в загальному це виглядає
HTML

<div class="flex-container">
  <div class="flex-item" style="background-image:url(<?=$image?>);background-repeat: repeat-y;width:20px;"></div><!-- HEADER.PHP --> 
  <div class="flex-item">Вміст...</div><!-- INDEX.PHP --> 
  <div class="flex-item" style="background-image:url(<?=$image?>);background-repeat: repeat-y;width:20px;"></div><!-- FOOTER.PHP --> 
</div>

$image - це шлях до картинки, статично шлях задати не можливо - шлях завантажується з БД.

Проблеми такі
1) Мені потрібно два рази, для двох файлів, заходити в БД, спочатку header, а потім footer, тому що footer, звичайно, не бачить змінну яка знаходиться у header (змінну $image)
2) Було б набагато ліпше закинути стилі в файл для стилів, а в div просто додати клас, але в CSS не буде виконуватися PHP код, як передати в CSS файл шлях до зображення, який може динамічно змінитися.

Допоможіть вирішити ці проблеми.

Хочу запитати про GPLv2. Я хочу створити тему для wordpress на основі bootstrap, можливо я буду використовувати ще якість безкоштовні засоби, я маю право "вкинути" в свою інтелектуальну власність "чужий" засіб(код, картинку, музику) який створений під вільною ліцензією GPLv2 або іншою ? Звичайно, потім я буду опубліковувати свою тему для wordpress.

Прихований текст
Я читав ліцензію і знаю про "the freedom to share the changes you make", але все таки хотів би уточнити...

5

(4 відповідей, залишених у HTML та CSS)

Я бачу багато цікавих анімацій css, але навіщо навантажувати сторінку, і ускладнювати відображення її, краще анімації вставляти у вигляді gif. Напевно дивне питання: Є які способи конвертувати css в gif ? Як такі задачі вирішувати ?

Прихований текст
Звичайно я гуглив, але всі "онлайн конвертори" працюють неадекватно

Ось наприклад
html

<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>

css

div {
  border-radius:50%;
  position:absolute;
  top:50%; left:75%;
}
div:nth-of-type(odd) { background:black; }
div:nth-of-type(even) { background:white; border:2px solid black; }
div:nth-of-type(11) {
  height:10px; width:10px;
  margin-top:-5px; margin-left:-5px;
  -webkit-animation:slide 3s ease-in-out infinite;
  animation:slide 3s ease-in-out infinite;
}
div:nth-of-type(10) {
  height:20px; width:20px;
  margin-top:-12px; margin-left:-12px;
  -webkit-animation:slide 3s -2.7s ease-in-out infinite;
  animation:slide 3s -2.7s ease-in-out infinite;
}
div:nth-of-type(9) {
  height:40px; width:40px;
  margin-top:-20px; margin-left:-20px;
  -webkit-animation:slide 3s -2.4s ease-in-out infinite;
  animation:slide 3s -2.4s ease-in-out infinite;
}
div:nth-of-type(8) {
  height:60px; width:60px;
  margin-top:-32px; margin-left:-32px;
  -webkit-animation:slide 3s -2.1s ease-in-out infinite;
  animation:slide 3s -2.1s ease-in-out infinite;
}
div:nth-of-type(7) {
  height:80px; width:80px;
  margin-top:-40px; margin-left:-40px;
  -webkit-animation:slide 3s -1.8s ease-in-out infinite;
  animation:slide 3s -1.8s ease-in-out infinite;
}
div:nth-of-type(6) {
  height:100px; width:100px;
  margin-top:-52px; margin-left:-52px;
  -webkit-animation:slide 3s -1.5s ease-in-out infinite;
  animation:slide 3s -1.5s ease-in-out infinite;
}
div:nth-of-type(5) {
  height:120px; width:120px;
  margin-top:-60px; margin-left:-60px;
  -webkit-animation:slide 3s -1.2s ease-in-out infinite;
  animation:slide 3s -1.2s ease-in-out infinite;
}
div:nth-of-type(4) {
  height:140px; width:140px;
  margin-top:-72px; margin-left:-72px;
  -webkit-animation:slide 3s -0.9s ease-in-out infinite;
  animation:slide 3s -0.9s ease-in-out infinite;
}
div:nth-of-type(3) {
  height:160px; width:160px;
  margin-top:-80px; margin-left:-80px;
  -webkit-animation:slide 3s -0.6s ease-in-out infinite;
  animation:slide 3s -0.6s ease-in-out infinite;
}
div:nth-of-type(2) {
  height:180px; width:180px;
  margin-top:-92px; margin-left:-92px;
  -webkit-animation:slide 3s -0.3s ease-in-out infinite;
  animation:slide 3s -0.3s ease-in-out infinite;
}
div:nth-of-type(1) {
  height:200px; width:200px;
  margin-top:-100px; margin-left:-100px;
  -webkit-animation:slide 3s ease-in-out infinite;
  animation:slide 3s ease-in-out infinite;
}
@keyframes slide {
  0% { left:75% }
  50% { left:25%; }
  100% { left:75%; }
}
@-webkit-keyframes slide {
  0% { left:75% }
  50% { left:25%; }
  100% { left:75%; }
}

6

(5 відповідей, залишених у Інше)

Прихований текст

221VOLT написав:
Betterthanyou написав:

Якщо ні, підскачіть як розв'язати задачу.

підскочив!

Прихований текст
то не задача а якийсь мозгосекс
імхо  :D

Уууупс... опечатка, виправив

Задача
За допомогою пружини жорсткістю 96 Н/м брусок масою 2,4 кг рівномірно
тягнуть по столу. Яким є видовження пружини, якщо коефіцієнт
тертя між бруском і столом дорівнює 0,2?

Дані:
R = 96 H/м жорсткість
m = 2,4 кг маса
μ = 0,2 коефіцієнт тертя ковзання
х - ? м видовження

Алгоритм розв'язувати задачу
1) Знайти силу тертя ковзання
2) Знаходження відсоткового відношення двох чисел (Н жорсткості і Н сили тертя сковзання)

Fтертя ковз = μ * N
μ - коефіцієнт тертя ковзання
N - сила нормальної реакції опори

Якщо на горизонтальній поверхні на тіло у вертикальному напрямку не діють ніякі сили, крім сили тяжіння та сили нормальної реакції то N = mg, m - маса, g - прискорення вільного падіння
g = 9,8 H/к

Fтертя ковз = 2,4*9,8*0,2 = 4.7 Н

Якщо 96Н потрібно для 100 см, то 4,7Н
4,7Н / 96Н * 100(%) = 4,8 см
потрібно для 4,8 см (?)

Я не впевнений в правильності мого розв'язку, правильно розв'язана задача ? Якщо ні, підкажіть як розв'язати задачу.

8

(21 відповідей, залишених у JavaScript)

FakiNyan написав:

туторіали для розуміння конкретних штук, а не базису

Тоді можливо ви шукаєте книжку про JavaScript паттерни ?

9

(21 відповідей, залишених у JavaScript)

не книжка, але все таки

10

(5 відповідей, залишених у HTML та CSS)

Є якийсь спосіб зберегти веб сторінку в одному файлі, наприклад коли я хочу конвертувати docx в html ? Я читав про формат MHTML там використовується позиційна система числення Base64 для кодування файлів. Я зберіг(конвертував) файл docx в mhtml і відкрив за допомогою notepad, мене здивували "абсолютні шляхи до файлу", наприклад "file:///C:/8F697F45/file5749.files/props0002.xml" чи "file:///C:/8F697F45/file5749.htm". - що це таке ?
Також не зрозуміло як відкрити MHTML в будь-якому браузері за виключенням windows explorer. Наприклад в опері зображення не відображаються (тільки в windows explorer вміст відображається повністю).
Тут напевно слід сказати що конвертував Microsoft Office 2007 можливо в новіших версіях працює конвертований MHTML, якщо так то напишіть.
Та й взагалі не зрозуміло навіщо MHTML якщо браузери підтримують Base64 у звичайному HTML
Ось приклад

<!doctype HTML public "-//W3C//DTD HTML 4.01//EN"
   "http://www.w3.org/TR/html4/strict.dtd">
<html>
   <head>
      <title>Base64</title>
   </head>
   <body>
<img src="">
</body>
</html>

Є якийсь спосіб конвертувати DOCX в HTML із всіма файлами ? ("веб сторінка" та "веб сторінка з фільтрами" створює директорію із зображеннями і файлами тому такий варіант не підходить)

11

(6 відповідей, залишених у C/C++)

Я зробив переклад теми "Обмін даними між паралельними процесами у Windows", кому цікаво можете подивитися, всі приклади працюють - я перевіряв.
Можливо потім скину проекти в github, просто зараз не вистачає часу.
За сайт вибачайте, розумію що він жахливий, я взагалі не знайомий з Google Blog тому ближчим часом планую зробити що інше.
Сайт
Word document

Я думаю що в когось з форумчан є вже електронна книга, тому хочу почути вашу пораду. Я читаю безкоштовні книги і старі книги з монітора (тому що я, ті книги, не можу читати в паперовій версії, в паперовій версії їх не існує), але в мене втомлюються очі, тому задумався про покупку електронної книги. В електронній книзі мене бентежать малі розміри дисплею, всього 6 дюймів в більшості книг. Якщо говорити про безперервне читання протягом 4 годин, як буде зручніше, читати з електронної книги чи з монітора ? (Якщо бути більш конкретним, то я хочу купити EvroMedia HD Extra Light).

Kasper написав:

...вони автоматом зберігаються в папку коли створено запис (.../2017/05/...), а потрібно щоб вони зберігались в папку  сьогоднышньоъ дати (.../2017/08/...). ...

Тобто старі файли в папці ".../2017/05/...", а нові ".../2017/08/..." ? Розкидати файли - якось не правильно на мою думку, можливо краще шукати спосіб як можна (автоматично) перейменувати папку з ".../2017/05/..." на ".../2017/08/..." зразу після редагування ?

14

(4 відповідей, залишених у Залізо)

microsoft написав:

Режим сну

У цьому режимі ваш комп’ютер споживатиме зовсім небагато електроенергії та запускатиметься швидше, а ви зможете працювати далі з того місця, де закінчили. Не потрібно переживати, що результати роботи буде втрачено через вичерпання ресурсу акумулятора. Якщо рівень заряду акумулятора стає занизьким, ОС Windows автоматично зберігає всі результати роботи та вимикає ПК. Використовуйте режим сну, якщо збираєтеся відійти від ПК ненадовго – наприклад, щоб випити кави.

Багато комп’ютерів (зокрема, ноутбуків і планшетів) переходять у режим сну, коли ви їх закриваєте або натискаєте кнопку живлення.

Щоб перевести ПК в режим сну:

Відкрийте параметри живлення:
Якщо у вас Windows 10, у полі пошуку на панелі завдань введіть електроживлення, а потім виберіть елемент Електроживлення.
У Windows 8.1 або Windows RT 8.1 проведіть пальцем від краю екрана (якщо ви використовуєте мишу, перемістить вказівник до правого верхнього кута екрана й проведіть ним вниз) і натисніть кнопку Пошук. У полі пошуку введіть Електроживлення, а потім виберіть елемент Електроживлення.
У Windows 7 натисніть кнопку "Пуск" Зображення кнопки , а потім виберіть елементи Панель керування, Система та безпека й Електроживлення.
Виконайте одну з таких дій:
Якщо ви використовуєте настільний комп’ютер, планшет або ноутбук, виберіть елемент Виберіть дії, за які відповідають кнопки живлення. Поруч з елементом Після натискання кнопки живлення виберіть варіант Сон, а потім натисніть кнопку Зберегти зміни.
Якщо ви використовуєте лише ноутбук, виберіть елемент Виберіть дію для закриття кришки ноутбука. Поруч з елементом Після закриття кришки виберіть варіант Сон, а потім натисніть кнопку Зберегти зміни.
Коли ПК потрібно перевести в режим сну, просто натисніть кнопку живлення на настільному комп’ютері, планшеті чи ноутбуку або закрийте кришку ноутбука.
Відповідь на ваше питання: На більшості комп’ютерів ви можете продовжити роботу, натиснувши кнопку живлення. Проте не всі комп’ютери однакові. Деякі можна вивести з режиму сну, натиснувши будь-яку клавішу на клавіатурі, натиснувши кнопку миші або відкривши кришку ноутбука. Перегляньте документацію комп’ютера або відвідайте веб-сайт виробника.

Логічні команди та їх використання
Задача
Задано двадцять однобайтових кодів, у кожному коді, у якому розряди 3,4,5,6,7 дорівнюють відповідно  1,1,0,0,1, поміняти всі розряди на протилежні, якщо ж вказана умова не виконується, то парні розряди поміняти на протилежні, а непарні встановити в нуль.

- Для початку потрібно видалити (встановити в нуль) 0,1,2 розряди коду, щоб легко порівняти код з 1,1,0,0,1, для цього я виконую дію "and" над маскою і кодом. (рядок 22-23)
- Порівняти маску "00011001" і код, в якому вже 0,1,2 розряди встановлені в нуль (рядок 24)
- Відновити початковий код (рядок 25)
- В задачі є схоже завдання в обох розгалуженнях - це поміняти розряди на протилежні, тож цю дію варто виконати перед розгалуженням JE (рядок 26)
- Якщо код і маска "00011001" не є рівними, то непарні розряди зануляться, для встановлення непарним розрядам нуль, потрібно виконати дію "and" над маскою "10101010" і кодом. Дія "not" вже виконана перед цим (рядок 29)

data segment
    ARR1 DB 74d, 225d, 84d, 12d, 36d, 99d, 74d, 124d, 87d, 144d, 223d, 177d, 8d, 41d, 160d, 133d, 154d, 111d, 249d, 20d
    SIZE_OF_ARR1 DB $-ARR1
ends
code segment
start:
; set segment registers:
    mov ax, data
    mov ds, ax
    
    MOV BL, 01Fh ;MASK 00011111b (OR 01Fh)
    MOV BH, 019h ;MASK 00011001b (OR 019h)
    MOV DL, 0AAh ;MASK 10101010 (OR 0AAh)
    
    ;SETUP SIZE OF ARR1
    MOV CH, 0                        
    MOV CL, SIZE_OF_ARR1            
    MOV SI, CX
    DEC SI;START WITH 19 ELEMENT
    
    LOOP1:
    MOV AH, ARR1[SI];SETUP VALUE
    AND AH, BL      ;USE A MASK FOR DELETE THE FIRST THREE BITS
    CMP AH, BH      ;COMPARE THIS BYTE AND A MASK
    MOV AH, ARR1[SI];SETUP AGAIN THE SAME BYTE (VALUE) IN ORDER TO RESTORE THE FIRST THREE BITS
    NOT AH                          
    JE EQUAL
    ;DO NOT EQUAL
    AND AH, DL
    EQUAL:                              
    MOV ARR1[SI], AH
    DEC SI
    LOOP LOOP1
    
    mov ax, 4c00h ; exit to operating system.
    int 21h    
ends

end start ; set entry point and stop the assembler.

16

(4 відповідей, залишених у Інше)

Vo_Vik написав:

q and not p
Чи нє?

Ні, я ж про це писав

Betterthanyou написав:

Тепер буду використовувати аналоги p∧~q
p = 01010101
q = 00110100
~q = 11001011
p∧~q = 01000001
ну і звичайно
00100000 != 01000001

Чомусь q and not p (воно ж p∧~q) не дорівнює 00100000

Я написав що, на приклад "p = 01010101", а "q = 00110100"
Заперечення q, NOT q =  11001011
Логічне "і", p and (not q) = 01000001

Але якщо робити за таблицею, виходить
  01010101
  00110100
=00100000

00100000 не дорівнює 01000001, тепер зрозуміло ?

17

(4 відповідей, залишених у Інше)

Мені потрібний такий логічний елемент
p ↛  q  result
0      0  0
0      1  1
1      0  0
1      1  0
такий елемент називається "аб'ю́нкція", на вікіпедії написано що аб'ю́нкція рівна p∧~q

Для початку зроблю приклад з використанням таблиці аб'ю́нкції
p = 01010101
q = 00110100
p ↛ q = 00100000

Тепер буду використовувати аналоги p∧~q
p = 01010101
q = 00110100
~q = 11001011
p∧~q = 01000001

ну і звичайно
00100000 != 01000001

Де ж я зробив помилку ?
Мені потрібно замінити аб'ю́нкцію використовуючи будь-які операції із NOT, AND, OR, XOR як це зробити ?

reverse2500 написав:

ще

CALL [ESP]

еквівалент

RET

Перевірив

P2 PROC         
CALL [SP]

Помилка
"wrong parameters: CALL [SP]"

Що означають [] (квадратні дужки) ? - Я подивився що це адрес операнда (а не значення стеку), а для того щоб подивитися значення стек потрібно використати команду "top" (top: отримати верхній елемент (без виштовхування).) - якої в асемблері немає. Звісно що я ще не достатньо добре знаю асемблер, тому якщо я помилився - поправте мене

koala написав:

CALL - це PUSH+JMP, а RET - це POP+JMP.

Якщо ж використати "POP", то виходить замінити ret на call - але навіщо тоді це

P2 PROC        
        POP AX 
CALL AX;В стек появиться адрес AX який потім потрібно буде виштовхнути 
koala написав:

вручну обчислювали?

Так

koala написав:

Хіба не логічніше було б поставити мітки в тих місцях, куди відбуваються переходи, і хоча б їх у стек пхати - не кажу вже про те, щоб описувати перед функцією вимоги до її виклику (стан регістрів і стеку)?

Щось я про це не подумав, вже не хочу перероблювати.

Щодо вимог виклику функцій

DERERMINANT2X2 - для самостійного використання не призначена (спочатку там потрібно видалити додаткові операції, рядок 40)

DETERMINANT3X3 - Стан регістів не важливий, але регістри AX, BX, CX, DX, BP - будуть змінені.
Не записувати в 3-7,9-13,15-19 більше чим +/-181 (елементи матриці не можуть бути більші чим 181 - не вистаціть пам'яті для арифметики ).
В стеку повинні бути (перед цім можна записати AX, BX, CX, DX, BP в стек, щоб потім їх відновити):
1 - куди повернутися після завершення роботи функції
2 - адреса рядка "ADD AX, CX" функції "DERERMINANT2X2"
3 - елемент (комірка) матриці a13
4 - елемент (комірка) матриці a21
5 - елемент (комірка) матриці a32
6 - елемент (комірка) матриці a22
7 - елемент (комірка) матриці a31
8 - адреса рядка "SUB CX, AX" функції "DERERMINANT2X2"
9 - елемент (комірка) матриці a12
10 - елемент (комірка) матриці a21
11 - елемент (комірка) матриці a33
12 - елемент (комірка) матриці a23
13 - елемент (комірка) матриці a31
14 - адреса рядка "MOV CX, AX" функції "DERERMINANT2X2"
15 - елемент (комірка) матриці a11
16 - елемент (комірка) матриці a22
17 - елемент (комірка) матриці a33
18 - елемент (комірка) матриці a23
19 - елемент (комірка) матриці a32
Результат виконання функції буде в регістрі АХ, тобто визначник матриці

20

(3 відповідей, залишених у Інше)

Зрозумів помилку, дякую