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

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

29.10.2020, 20:00. Показов 5399. Ответов 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
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
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
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
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
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
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
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
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
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru