Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.84/25: Рейтинг темы: голосов - 25, средняя оценка - 4.84
5 / 5 / 0
Регистрация: 20.10.2020
Сообщений: 53

Задача D. Проект "Ровные дороги" 2

29.10.2020, 20:00. Показов 5453. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
При проектировании новой автодороги было принято решение сделать её не более чем из двух абсолютно горизонтальных участков. Будущую трассу разбили на n равных по длине малых отрезков. Будем считать, что в пределах одного малого отрезка местность имеет одну и ту же высоту h_i. При этом в целях эффективной трансформации местности требуется для выравнивания использовать исключительно грунт с этой же трассы. Это означает, что можно с некоторого малого отрезка высоты h_i взять некоторое количество грунта d так, что высота этого участка станет h_i - d > 0. Далее эти d единиц грунта обязательно нужно переместить на другой малый отрезок высоты h_j так, что его высота станет h_j + d. Перемещать грунт можно только в пределах одного из двух выбранных участков, то есть отрезки номер i и номер j должны принадлежать одному и тому же горизонтальному после выравнивания участку. В данной версии задачи высоты выравниваемых участков могут быть любыми положительными, в том числе и не целыми числами. Следующим важным вопросом при строительстве являются трудозатраты. По этой причине требуется выбрать такое разбиение трассы ровно на два непустых участка, чтобы суммарный объём перемещенного грунта был минимально возможным.

Формат входных данных

В первой строке содержится число n - количество малых отрезков, на которые разбили трассу, 2≤n≤2∗10^5. Во второй строке указаны высоты h_i этих отрезков через пробел в порядке слева направо, 1≤h≤2∗10^5.

Формат выходных данных

Вывести два ненулевых числа a и b через пробел. Их сумма должна равняться n. Отрезки с номерами c первого по a-й включительно будут принадлежать первому выровненному участку, отрезки с номерами от a+1 до n будут принадлежать второму выровненному участку. При этом суммарный объём грунта, перемещенного для такого выравнивания, должен быть минимальным среди всех возможных разбиений трассы на два участка. Если минимальных вариантов несколько вывести тот, у которого число a меньше.

Sample Input:

8
8 20 2 10 4 3 1 1
Sample Output:

4 4
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.10.2020, 20:00
Ответы с готовыми решениями:

Проект "Ровные дороги" 2 Нужна оптимизация решения
Всем привет. Имею такую задачу: Задача С. Послание внеземного разума 3 Профессор Персиков снова на первых полосах новостных...

Проект "Ровные дороги" 2
При проектировании новой автодороги было принято решение сделать её не более чем из двух абсолютно горизонтальных участков. Будущую трассу...

Проект "Ровные дороги"
помогите пожалуйста Задача D1. Проект "Ровные дороги" При проектировании новой автодороги было принято решение сделать её не более чем...

15
20 / 19 / 2
Регистрация: 19.06.2019
Сообщений: 45
30.10.2020, 18:47
Решение в следующем:
Подумаем, что нам необходимо сделать в этой задаче:
Нужно как то быстро считать среднюю сумму на отрезке, а так же быстро считать сумму элементов больше какогото числа.
Нам поможет структура данных - дерево отрезков.
Реализуем два дерева отрезков. 1 для левого отрезка, 2 для правого. Обновлять и считать суммы мы будем онлайн.
Но как узнать сумму элементов больше данного числа? Воспользумся следующем способом:
1) отсортируем изначальный массив.
2) запомним позиции каждого числа, который стоят в отсортированном массиве.
Теперь длаем следующее:
при каждом рассмотрении отрезков, мы в наше первое ДО будем добавлять элемент, который должен на данном шаге включаться в левый отрезок, но ставить мы его будем на ту позицию, которая принадлежит этому числу в отсортированном массиве, а в правом отрезке заменять это число на 0. Теперь нам будет легко найити сумму чисел больше данного вот так:
В отсортированном массиве с помощью бин поиска найдем ту позицию, где суффикс это массива содержит числа больше либо равных данному числу. Далее найдем сумму на нашем ДО от той позиции который нашел бин поиск до самого конца массива. Таким образом мы нашли сумму элементов больше либо равно заданному числу.
С помощью этих двух операций можно легко решить задачу.

Временная сложность n log n
2
0 / 0 / 0
Регистрация: 30.10.2020
Сообщений: 4
30.10.2020, 22:34
C++
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
#include <iostream>
#include <vector>
using namespace std;
int main() {
    int n;
    cin >> n;
    vector <int> s(n);
    int answ1 = 0, answ2 = 0, ANSW1 = 0, ANSW2 = 0;
    double answ = 0, ANSW = 0;
    int cnt1 = 0, cnt2 = 0;
    double height1 = 0, height2 = 0;
    for (int i = 0; i < n; i++) {
        cin >> s[i];
    }
    for (int i = 2; i < n - 1; i++) {
        for (int I = 0; I < n; I++) {
            if (I < i) {
                cnt1 += s[I];
            }
            else {
                cnt2 += s[I];
            }
        }
        answ1 = i;
        answ2 = n - i;
        height1 = (double)cnt1 / answ1;
        height2 = (double)cnt2 / answ2;
        for (int I = 0; I < answ1; I++) {
            if (s[I] > height1) {
                answ += s[I] - height1;
            }
        }
        for (int I = answ1; I < n; I++) {
            if (s[I] > height2) {
                answ += s[I] - height2;
            }
        }
        if (i == 2) {
            ANSW = answ;
            ANSW1 = answ1;
            ANSW2 = answ2;
        }
        else if (answ < ANSW) {
            ANSW = answ;
            ANSW1 = answ1;
            ANSW2 = answ2;
        }
        answ = 0;
        height1 = 0;
        height2 = 0;
        cnt1 = 0;
        cnt2 = 0;
    }
    cout << ANSW1 << " " << ANSW2;
    return 0;
}
0
5 / 5 / 0
Регистрация: 20.10.2020
Сообщений: 53
31.10.2020, 07:57  [ТС]
Цитата Сообщение от Petuha Посмотреть сообщение
C++
5 из 24 тестов, остальные летят за неправильный ответ или время
0
3 / 3 / 0
Регистрация: 19.10.2020
Сообщений: 11
31.10.2020, 11:33
Romiusse
Решение в следующем:
Подумаем, что нам необходимо сделать в этой задаче:
Нужно как то быстро считать среднюю сумму на отрезке, а так же быстро считать сумму элементов больше какогото числа.
Нам поможет структура данных - дерево отрезков.
Реализуем два дерева отрезков. 1 для левого отрезка, 2 для правого. Обновлять и считать суммы мы будем онлайн.
Но как узнать сумму элементов больше данного числа? Воспользумся следующем способом:
1) отсортируем изначальный массив.
2) запомним позиции каждого числа, который стоят в отсортированном массиве.
Теперь длаем следующее:
при каждом рассмотрении отрезков, мы в наше первое ДО будем добавлять элемент, который должен на данном шаге включаться в левый отрезок, но ставить мы его будем на ту позицию, которая принадлежит этому числу в отсортированном массиве, а в правом отрезке заменять это число на 0. Теперь нам будет легко найити сумму чисел больше данного вот так:
В отсортированном массиве с помощью бин поиска найдем ту позицию, где суффикс это массива содержит числа больше либо равных данному числу. Далее найдем сумму на нашем ДО от той позиции который нашел бин поиск до самого конца массива. Таким образом мы нашли сумму элементов больше либо равно заданному числу.
С помощью этих двух операций можно легко решить задачу.

Временная сложность n log n
Окей а что делать после того как мы подсчитали сумму элементов больше среднего?

Добавлено через 8 минут
Нам же надо найти сумму n чисел болших чем sr - n*sr. Но при этом чему равно n? Из-за того что какие-то из чисел нули n будет тяжело найти
0
20 / 19 / 2
Регистрация: 19.06.2019
Сообщений: 45
31.10.2020, 11:35
DarkSwwwan, производить арифметические операции) если задачу прочитать и картинки к ней посмотреть, то там все написано что дальше делать
0
0 / 0 / 0
Регистрация: 16.10.2020
Сообщений: 3
31.10.2020, 12:47
так вопрос находится в разделе питон, а не с++
0
3 / 3 / 0
Регистрация: 19.10.2020
Сообщений: 11
31.10.2020, 14:22
Romiusse,
1. Какие картинки я чё-то не вдупляю
2. Как ты поймёшь сколько из слагаемых подсчитанной суммы у тебя равны нулю, при этом не перебирая массив
0
20 / 19 / 2
Регистрация: 19.06.2019
Сообщений: 45
31.10.2020, 14:31
DarkSwwwan, для этого можно построить ещё одно до, состоящее из 0 и 1,где 1 находится число на итой позиции, а 0 нет.
Значит простой суммой на отрезке, мы можем узнать слагаемых равны 0
1
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
31.10.2020, 15:36
Romiusse, по времени вылетает
0
20 / 19 / 2
Регистрация: 19.06.2019
Сообщений: 45
31.10.2020, 16:11
Gdez, по времени все норм, т.к решение за n log n
C++
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
#include <vector>
#include <iostream>
#include <algorithm>
#include <cmath>
#include <set>
#include <string>
#include <map>
#include <numeric>
#include <queue>
#include <functional>
#include <stack>
#include <iomanip>
#include <bitset>
using namespace std;
 
struct pos {
    long long a, b, c;
};
 
bool comp(pos a, pos b) {
 
    return a.a < b.a;
 
}
 
void build(vector<long long> &a, long long v, long long tl, long long tr, vector<long long> &t) {
    if (tl == tr)
        t[v] = a[tl];
    else {
        long long tm = (tl + tr) / 2;
        build(a, v * 2, tl, tm ,t);
        build(a, v * 2 + 1, tm + 1, tr,t);
        t[v] = t[v * 2] + t[v * 2 + 1];
    }
}
 
void update(long long v, long long tl, long long tr, long long pos, long long new_val, vector<long long>& t) {
    if (tl == tr)
        t[v] = new_val;
    else {
        long long tm = (tl + tr) / 2;
        if (pos <= tm)
            update(v * 2, tl, tm, pos, new_val,t);
        else
            update(v * 2 + 1, tm + 1, tr, pos, new_val,t);
        t[v] = t[v * 2] + t[v * 2 + 1];
    }
}
 
long long sum(long long v, long long tl, long long tr, long long l, long long r, vector<long long>& t) {
    if (l > r)
        return 0;
    if (l == tl && r == tr)
        return t[v];
    long long tm = (tl + tr) / 2;
    return sum(v * 2, tl, tm, l, min(r, tm),t)
        + sum(v * 2 + 1, tm + 1, tr, max(l, tm + 1), r,t);
}
 
int main()
{
 
    long long n,aa = 0,ab = 0; cin >> n;
    long double ans = 10e17;
    vector<pos> used(n);
    vector<long long> v(n), vs, va(4 * n),vza(4 * n), vb(4 * n),vzb(4 * n),ones(n,1); for (int i = 0; i < n; i++) cin >> v[i];
    vs = v; sort(vs.begin(), vs.end());
    for (int i = 0; i < n; i++) used[i] = { v[i],i,0 };
    sort(used.begin(), used.end(),comp); //значение обычн 0
    for (int i = 0; i < n; i++) used[i].c = i, swap(used[i].a, used[i].b); 
    sort(used.begin(), used.end(),comp); //обычн значение отсорт
    build(vs, 1, 0, n - 1, vb);
    build(ones, 1, 0, n - 1, vzb);
    for (int i = 0; i < n - 1; i++) {
        pos p = used[i];
 
        update(1, 0, n - 1, p.c, p.b, va);
        update(1, 0, n - 1, p.c, 0, vb);
        update(1, 0, n - 1, p.c, 1, vza);
        update(1, 0, n - 1, p.c, 0, vzb);
 
        long double suma = sum(1, 0, n - 1, 0, n - 1, va), sumb = sum(1, 0, n - 1, 0, n - 1, vb);
        long double avra = suma / ((double)i + 1), avrb = sumb / ((double)n - i - 1);
        auto itra = lower_bound(vs.begin(),vs.end(),ceil(avra));
        auto itrb = lower_bound(vs.begin(), vs.end(), ceil(avrb));
        long double ansa = sum(1, 0, n - 1, itra - vs.begin(), n - 1, va);
        ansa -= avra * sum(1, 0, n - 1, itra - vs.begin(), n - 1, vza);
        long double ansb = sum(1, 0, n - 1, itrb - vs.begin(), n - 1, vb);
        ansb -= avrb * sum(1, 0, n - 1, itrb - vs.begin(), n - 1, vzb);
        if (ansa + ansb < ans) {
            ans = ansa + ansb;
            aa = i + 1;
            ab = n - aa;
        }
    }
    cout << aa << " " << ab << endl;
 
    
}
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
31.10.2020, 16:18
Romiusse,
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#n = 8
#a = [8, 20, 2, 10, 4, 3, 1, 1]
n = int(input())
a = list(map(int,input().split()))
suma = sum(a)
res = suma
t = 0
for i in range(n - 1) :
    t += a[i]
    s1 = t / (i + 1)
    s2 = (suma - t) / (n - i -1)
    s11 = sum([ j  - s1 for j in a[:i + 1] if j > s1]) + sum([ j  - s2 for j in a[i + 1:] if j > s2])
    if res > s11 :
        res = s11
        l = i + 1
        r = n - i - 1
#print(res)
print(l, r)
0
20 / 19 / 2
Регистрация: 19.06.2019
Сообщений: 45
31.10.2020, 16:20
Gdez, у вас решение за квадрат, как я понял, поэтому и не проходит по времент
0
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
31.10.2020, 16:25
Romiusse, возможно - тестера не было
Я не сдавал . Мне сказали, что вылетает
0
3 / 3 / 0
Регистрация: 19.10.2020
Сообщений: 11
31.10.2020, 21:13
Ну ясен пень тебе же сказали построить ДО, а ты тупо циклом вигачишь.
Вот если нужно хороший код дерева отрезков, для нахождения суммы. Мне помог
Python
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
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
# Python3 program to show segment tree operations like
# construction, query and update  
from math import ceil, log2; 
  
# A utility function to get the 
# middle index from corner indexes.  
def getMid(s, e) : 
    return s + (e -s) // 2;  
  
""" A recursive function to get the sum of values  
    in the given range of the array. The following  
    are parameters for this function.  
  
    st --> Pointer to segment tree  
    si --> Index of current node in the segment tree.  
           Initially 0 is passed as root is always at index 0  
    ss & se --> Starting and ending indexes of the segment 
                represented by current node, i.e., st[si]  
    qs & qe --> Starting and ending indexes of query range """
def getSumUtil(st, ss, se, qs, qe, si) :  
  
    # If segment of this node is a part of given range,  
    # then return the sum of the segment  
    if (qs <= ss and qe >= se) : 
        return st[si];  
  
    # If segment of this node is 
    # outside the given range  
    if (se < qs or ss > qe) : 
        return 0;  
  
    # If a part of this segment overlaps  
    # with the given range  
    mid = getMid(ss, se);  
      
    return getSumUtil(st, ss, mid, qs, qe, 2 * si + 1) + getSumUtil(st, mid + 1, se, qs, qe, 2 * si + 2)
  
""" A recursive function to update the nodes  
which have the given index in their range.  
The following are parameters st, si, ss and se  
are same as getSumUtil()  
i --> index of the element to be updated.  
      This index is in the input array.  
diff --> Value to be added to all nodes  
which have i in range """
def updateValueUtil(st, ss, se, i, diff, si) :  
  
    # Base Case: If the input index lies  
    # outside the range of this segment  
    if (i < ss or i > se) : 
        return;  
  
    # If the input index is in range of this node,  
    # then update the value of the node and its children  
    st[si] = st[si] + diff;  
      
    if (se != ss) : 
      
        mid = getMid(ss, se);  
        updateValueUtil(st, ss, mid, i,  
                        diff, 2 * si + 1);  
        updateValueUtil(st, mid + 1, se, i,  
                         diff, 2 * si + 2);  
  
# The function to update a value in input array  
# and segment tree. It uses updateValueUtil()  
# to update the value in segment tree  
def updateValue(arr, st, n, i, new_val) :  
  
    # Check for erroneous input index  
    if (i < 0 or i > n - 1) : 
          
        print("Invalid Input", end = "");  
        return;  
  
    # Get the difference between  
    # new value and old value  
    diff = new_val - arr[i];  
  
    # Update the value in array  
    arr[i] = new_val;  
  
    # Update the values of nodes in segment tree  
    updateValueUtil(st, 0, n - 1, i, diff, 0);  
  
# Return sum of elements in range from  
# index qs (quey start) to qe (query end). 
# It mainly uses getSumUtil()  
def getSum(st, n, qs, qe) :  
  
    # Check for erroneous input values  
    if (qs < 0 or qe > n - 1 or qs > qe) : 
  
        print("Invalid Input", end = "");  
        return -1;  
      
    return getSumUtil(st, 0, n - 1, qs, qe, 0);  
  
# A recursive function that constructs  
# Segment Tree for array[ss..se].  
# si is index of current node in segment tree st  
def constructSTUtil(arr, ss, se, st, si) :  
  
    # If there is one element in array,  
    # store it in current node of  
    # segment tree and return  
    if (ss == se) : 
      
        st[si] = arr[ss];  
        return arr[ss];  
      
    # If there are more than one elements,  
    # then recur for left and right subtrees  
    # and store the sum of values in this node  
    mid = getMid(ss, se);  
      
    st[si] = constructSTUtil(arr, ss, mid, st, si * 2 + 1) + constructSTUtil(arr, mid + 1, se, st, si * 2 + 2)
      
    return st[si];  
  
""" Function to construct segment tree  
from given array. This function allocates memory 
for segment tree and calls constructSTUtil() to  
fill the allocated memory """
def constructST(arr, n) :  
  
    # Allocate memory for the segment tree  
  
    # Height of segment tree  
    x = (int)(ceil(log2(n)));  
  
    # Maximum size of segment tree  
    max_size = 2 * (int)(2**x) - 1; 
      
    # Allocate memory 
    st = [0] * max_size;  
  
    # Fill the allocated memory st  
    constructSTUtil(arr, 0, n - 1, st, 0);  
  
    # Return the constructed segment tree  
    return st;  
  
# Driver Code 
if __name__ == "__main__" :  
  
    arr = [i for i in range(10**6)]
    n = len(arr)
  
    # Build segment tree from given array  
    st = constructST(arr, n);  
  
    # Print sum of values in array from index 1 to 3  
    print("Sum of values in given range = ",
                       getSum(st, n, 1, 10**5))
  
    # Update: set arr[1] = 10 and update  
    # corresponding segment tree nodes  
    updateValue(arr, st, n, 1, 10);  
  
    # Find sum after the value is updated  
    print("Updated sum of values in given range = ", 
                     getSum(st, n, 1, 3), end = "");  
      
# This code is contributed by AnkitRai01
Добавлено через 1 минуту
Romiusse,
DarkSwwwan, для этого можно построить ещё одно до, состоящее из 0 и 1,где 1 находится число на итой позиции, а 0 нет.
Значит простой суммой на отрезке, мы можем узнать слагаемых равны 0
спасибо, уже разобрался
1
Эксперт Python
8851 / 4502 / 1864
Регистрация: 27.03.2020
Сообщений: 7,317
31.10.2020, 21:26
DarkSwwwan, молодец! Справился )
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.10.2020, 21:26
Помогаю со студенческими работами здесь

Задача Дороги
Дороги В галактике «Milky Way» на планете «Snowflake» есть N городов, некоторые из которых соединены дорогами. Император галактики...

Python - Задача D. Проект "Ровные дороги" 2
Задача D. Проект &quot;Ровные дороги&quot; 2 При проектировании новой автодороги было принято решение сделать её не более чем из двух абсолютно...

Проект "Ровные дороги" 2
При проектировании новой автодороги было принято решение сделать её не более чем из двух абсолютно горизонтальных участков. Будущую трассу...

Задача про дороги
Помогите решить задачку: Файл входных данных Z5.DAT Файл результатов Z5.SOL Файлы решения задачи Z5.* Текст задачи: В...

Задача про Дороги
Обозначим пункты Бишкек - B; Суусамырская Развилка - А; Жалал-Абад - J; Талас - Т; Ош - О; Каракол - К; Балыкчы - L; Нарын - N; Баткен -...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru