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

По номеру квартиры вычислить номер подъезда и номер этажа

16.03.2020, 16:24. Показов 25434. Ответов 69
Метки нет (Все метки)

Скорая помощь
Бригада скорой помощи выехала по вызову в один из отделенных районов. К сожалению, когда диспетчер получил вызов, он успел записать только адрес дома и номер квартиры K1, а затем связь прервалась. Однако он вспомнил, что по этому же адресу дома некоторое время назад скорая помощь выезжала в квартиру K2, которая расположена в подъезда P2 на этаже N2. Известно, что в доме M этажей и количество квартир на каждой лестничной площадке одинаково. Напишите программу, которая вычилсяет номер подъезда P1 и номер этажа N1 квартиры K1.

Входные данные

Во входном файле записаны пять положительных целых чисел K1, M, K2, P2, N2. Все числа не превосходят 1000.

Выходные данные

Выведите два числа P1 и N1. Если входные данные не позволяют однозначно определить P1 или N1, вместо соответствующего числа напечатайте 0. Если входные данные противоречивы, напечатайте два числа –1 (минус один).

Примеры
Ввод
89
20
41
1
11
Вывод
2 3
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.03.2020, 16:24
Ответы с готовыми решениями:

По номеру квартиры вычислить номер подъезда и номер этажа
Уважаемые форумчане! Представляю вашему вниманию задачу о скорой помощи. Скорая помощь Бригада скорой помощи выехала по вызову в один...

По номеру квартиры вычислить номер подъезда и номер этажа
Скорая помощь Бригада скорой помощи выехала по вызову в один из отделенных районов. К сожалению, когда диспетчер получил вызов, он успел...

Напишите программу, которая вычисляет номер подъезда и номер этажа по номеру квартиры
Бригада скорой помощи выехала по вызову в один из отделенных районов. К сожалению, когда диспетчер получил вызов, он успел записать только...

69
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:03
SeVikAle,
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
def checking(a1, a2, a3, a4):
    s1 = a1 + a2
    s2 = a3 + a4
    if s1 > s2:
        return int(str(s1) + str(s2))
    else:
        return int(str(s2) + str(s1))
 
v = int(input())
v_str = str(v)
v1 = str(v // 1000)
v2 = str((v % 1000) // 100)
v3 = str(((v % 1000) % 100) // 10)
v4 = str(((v % 1000) % 100) % 10)
v_n = int(v3 + v4 + v1 + v2)
ready = False
a = 1000
while ready == False:
    a1 = a // 1000
    a2 = (a % 1000) // 100
    a3 = ((a % 1000) % 100) // 10
    a4 = ((a % 1000) % 100) % 10
    x = checking(a1, a2, a3, a4)
    if x == v or x == v_n:
        ready = True
        print(a)
    else:
        if a >= 9999:
            print(0)
            ready = True
        else: a += 1
1
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:04
может поможет
0
1 / 1 / 0
Регистрация: 29.03.2019
Сообщений: 5
18.03.2020, 22:05
Короче вот ссылка там есть все тесты
https://www.olympiads.ru/mosco... hive.shtml

Добавлено через 55 секунд
короче вот ссылка там все тесты
https://www.olympiads.ru/mosco... hive.shtml
0
 Аватар для mikhfox
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 17
18.03.2020, 22:05
ProgrammerAnon, интересненько
0
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:07
вот ещё тесты
3
2
2
2
1
вывод -1 -1

Добавлено через 1 минуту
Цитата Сообщение от ProgrammerAnon Посмотреть сообщение
Короче вот ссылка там есть все тесты
https://www.olympiads.ru/mosco... hive.shtml
Добавлено через 55 секунд
короче вот ссылка там все тесты
https://www.olympiads.ru/mosco... hive.shtml
страница не запускается(((
0
 Аватар для mikhfox
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 17
18.03.2020, 22:08
Такс, сие надо на питоне/цпп написать. Вроде оно.
Pascal
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
program g;
{$APPTYPE CONSOLE}
type integer=longint;
     real=extended;
 
const maxn=1000000;
 
var vp,vn,p1,n1,k1,m,k2,p2,n2:integer;
 
procedure load;
begin
  read(k1,m,k2,p2,n2);
end;
 
procedure solve;
var inp,i,tp,tn,tk:integer;
begin
  vp:=0;
  vn:=0;
  p1:=-1;
  n1:=-1;
  for i:=1 to maxn do begin
    inp:=m*i;
    tp:=((k2-1) div inp)+1;
    tk:=k2-(tp-1)*inp;
    tn:=((tk-1) div i)+1;
    if (tp=p2) and (tn=n2) then begin
      tp:=((k1-1) div inp)+1;
      tk:=k1-(tp-1)*inp;
      tn:=((tk-1) div i)+1;
      if (n1=-1) then begin
        n1:=tn;
        vn:=1;
      end;
      if(p1=-1) then begin
        p1:=tp;
        vp:=1;
      end;
      if (vp>0) and (tp<>p1) then inc(vp);
      if (vn>0) and (tn<>n1) then inc(vn);
    end;
  end;
end;
 
procedure save;
begin
  if vp=0 then write('-1 ');
  if vp>1 then write('0 ');
  if vp=1 then write(p1,' ');
  if vn=0 then writeln('-1');
  if vn>1 then writeln('0');
  if vn=1 then writeln(n1);
end;
 
begin
  assign(input,'g.in');
  assign(output,'g.out');
  reset(input);
  rewrite(output);
  load;
  solve;
  save;
  close(input);
  close(output);
end.
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:13
mikhfox, если бы я хорошо знала паскаль, было бы легче... я из паскаля знаю только самое основное
0
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:15
Цитата Сообщение от Elya__U Посмотреть сообщение
если бы я хорошо знала паскаль, было бы легче... я из паскаля знаю только самое основное
тоже самое
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:16
LuKy_RoMiK, другого выхода пока нет, я попробую переделать, но не факт что получится
0
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:21
я то же попытаюсь
0
1 / 1 / 0
Регистрация: 12.03.2020
Сообщений: 13
18.03.2020, 22:27
Еще тесты

11
2
4
1
2

вывод 0 2

100
1
23
23
1

вывод 100 1

40
5
60
6
5

вывод 4 5
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:30
у меня плохо получается переводить((

Добавлено через 9 секунд
lektrik, спасибо
0
 Аватар для mikhfox
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 17
18.03.2020, 22:36
Перевел. Теперь фиксим!
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
#include <iostream>
using namespace std;
 
int main() {
    const int maxn = 1000000;
    long vp, vn, p1, n1, k1, m, k2, p2, n2, inp, i, tp, tn, tk;
    cin >> k1 >> m >> k2 >> p2 >> n2;
    
    vp = 0; vn = 0;
    p1 = -1; n1 = -1;
    for (i = 1; i <= maxn; i++) {
        inp = m * i;
        tp = ((k2 - 1) / inp) + 1;
        tk = k2 - (tp - 1) * inp;
        tn = ((tk - 1) / i) + 1;
        if (tp == p2 && tn == n2) {
            tp = ((k1 - 1) / inp) + 1;
            tk = k1 - (tp - 1) * inp;
            tn = ((tk - 1) / i) + 1;
            if (n1 == -1) {
                n1 = tn;
                vn = 1;
            }
            if (p1 == -1) {
                p1 = tp;
                vp = 1;
            }
            if (vp > 0 && tp != p1) vp++;
            if (vn > 0 && tn != n1) vn++;
        }
    }
    
    if (vp == 0) cout << '-1 ';
    if (vp > 1) cout << '0 ';
    if (vp == 1) cout << p1 << ' ';
    if (vn == 0) cout << '-1';
    if (vn > 1) cout << '0';
    if (vn == 1) cout << n1;
    return 0;
}
89 20 41 1 11 => 2 3
11 1 1 1 1 => 123201
11 2 4 1 2 => 123202
40 5 60 6 5 => 4 5
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:37
mikhfox, я знаю только питон(((
0
 Аватар для mikhfox
0 / 0 / 0
Регистрация: 03.01.2020
Сообщений: 17
18.03.2020, 22:38
Elya__U, в C++ удобнее всего было
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:39
у меня на питоне получилось что-то невнятное((
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
k1,m,k2,p2,n2= int(input()), int(input()), int(input()), int(input()), int(input())
vp=0
vn=0
p1=-1
n1=-1
maxn=1000000
for i in range(1, maxn+1) :
    inp =m*i
    tp =((k2-1) //inp)+1
    tk =k2-(tp-1)*inp
    tn =((tk-1) // i)+1
    if tp==p2 and tn==n2 :
        tp=((k1-1) // inp)+1;
        tk =k1-(tp-1)*inp
        tn=((tk-1) // i)+1
if n1==-1:
    n1=tn
    vn=1
if(p1==-1) :
    p1=tp
    vp=1;
if (vp>0) and (tp != p1): 
    vp += 1
if (vn>0) and (tn != n1) : 
    vn += 1
if vp==0 :
    print(-1 )
if vp>1: 
    print(0)
if vp==1 :
    print(p1)
if vn==0 :
    print(-1)
if vn>1 :
    print(0)
if vn==1 :
    print(n1)
0
8 / 6 / 2
Регистрация: 24.10.2019
Сообщений: 51
18.03.2020, 22:40
я знаю только C

Добавлено через 35 секунд
но в принципе можно и C++ отправить главное что бы работало
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:42
LuKy_RoMiK, ок, давайте пробовать на с++, я тоже попытаюсь что-нибудь сделать
0
1 / 1 / 0
Регистрация: 12.03.2020
Сообщений: 13
18.03.2020, 22:42
Цитата Сообщение от mikhfox Посмотреть сообщение
11 1 1 1 1 => 123201
11 2 4 1 2 => 123202
??? что ето?

должно быть

11 1 1 1 1 => 01
11 2 4 1 2 => 02

Компилятор:
Программа выводит ответ в неверном формате
0
2 / 2 / 0
Регистрация: 04.03.2020
Сообщений: 30
18.03.2020, 22:43
lektrik, я так поняла, что это ввод и вывод
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
18.03.2020, 22:43

Написать программу, которая вычисляет номер подъезда и номер этажа по номеру квартиры
Бригада скорой помощи выехала по вызову в один из отделенных районов. К сожалению, когда диспетчер получил вызов, он успел записать только...

Вычислить номер подъезда и номер этажа квартиры
Подскажите, пожалуйста, почему не работает программа, пишет, что int не могу использовать Код: K1 = int (input()) #1 номер квартиры M...

По номеру квартиры вычислить номер подъезда и номер этажа
Я знаю что её решали, но там нет правильного решения Помогите пожалуйста Скорая помощь Бригада скорой помощи выехала по вызову...

По номеру квартиры N определить номер подъезда и этажа
По номеру квартиры N определить номер подъезда и этажа. Квартира находится в K-этажном доме, на каждом этаже M квартир. Входные данные...

Определить номер подъезда и этажа по номеру квартиры девятиэтажного дома
Определить номер подъезда и этажа за номером квартиры девяти-этажного дома, учитывая, что на каждом этаже 4 квартиры, а нумерация квартир...


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

Или воспользуйтесь поиском по форуму:
60
Ответ Создать тему
Новые блоги и статьи
Своя Интернет-Компания
iceja 18.06.2026
Я программист с экономическим образованием, пишу свой проект, это SaaS для бизнесов. Мне нужен co-founder с высшим экономическим образованием, и/ или инвестор. Сейчас проект в интенсивной разработке,. . .
24 Мат модель здравосохранения: функциональные требования к строительству пищеблока
anaschu 18.06.2026
СРесурсами1: финансовый SD-контур, калькулятор функциональных требований пищеблока Сегодня разделили затраты в агенте Экономика по образцу модели НАСОСЫ, добавили расчёт ROI и построили первый. . .
23. что сделано за последнее время.
anaschu 17.06.2026
• Эталон: Клиника НИИ питания РАМН, Москва — централизованный пищеблок, 225 коек, 180 пациентов • Git: репозиторий med2, ветка абсентеизм. Рабочий файл: СРесурсами1_v4. alp • Смежный проект:. . .
22. Подключение слоя системной динамики (потоковые диффуры): экономические метрики модели
anaschu 17.06.2026
Апдейт модели: финансовый контур, разделение затрат Продолжаю развивать модель рабочего коллектива на AnyLogic. В этот раз работа шла над агентом Экономика — финансовым SD-слоем модели. Задача:. . .
[golang] Insert Delete GetRandom O(1) (Leetcode: 380)
alhaos 16.06.2026
Insert Delete GetRandom O(1) Сложность: Medium Источник: LeetCode 380 Задача Реализовать структуру данных RandomizedSet, которая поддерживает следующие операции за O(1) в среднем:
Свет в конце тоннеля
kumehtar 16.06.2026
Поймал себя на одной мысли. Раньше мне всегда казалось неправильным жить без чёткого понимания, куда всё идёт. Будто я иду по дороге судьбы, но не знаю, куда она ведёт. А раз не знаю — значит,. . .
[golang] Реализация стека с поддержкой получения минимального элемента за O(1)
alhaos 16.06.2026
Min Stack Сложность: Medium Источник: LeetCode 155 Задача: Реализовать стек который поддерживает push, pop, top и получение минимального элемента за O(1). Методы:
[golang] Конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов.
alhaos 10.06.2026
Задача Реализовать конкурентный fetcher с ограничением максимального количества одновременных HTTP запросов. Сигнатура func Fetch(urls string, maxConcurrent int) Result Пример urls :=. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru