Задания
Версия для печати и копирования в MS Word

Име­ет­ся набор дан­ных, со­сто­я­щий из пар по­ло­жи­тель­ных целых чисел. Не­об­хо­ди­мо вы­брать из каж­дой пары ровно одно число так, чтобы сумма всех вы­бран­ных чисел не де­ли­лась на 3 и при этом была ми­ни­маль­но воз­мож­ной. Га­ран­ти­ру­ет­ся, что ис­ко­мую сумму по­лу­чить можно. Про­грам­ма долж­на на­пе­ча­тать одно число  — ми­ни­маль­но воз­мож­ную сумму, со­от­вет­ству­ю­щую усло­ви­ям за­да­чи.

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

Файл A

Файл B

Даны два вход­ных файла (файл A и файл B), каж­дый из ко­то­рых со­дер­жит в пер­вой стро­ке ко­ли­че­ство пар N (1 ≤ N ≤ 100000). Каж­дая из сле­ду­ю­щих N строк со­дер­жит два на­ту­раль­ных числа, не пре­вы­ша­ю­щих 10 000.

При­мер ор­га­ни­за­ции ис­ход­ных дан­ных во вход­ном файле:

6

1 3

5 12

6 9

5 4

3 3

1 1

Для ука­зан­ных вход­ных дан­ных зна­че­ни­ем ис­ко­мой суммы долж­но быть число 20.

В от­ве­те ука­жи­те два числа: сна­ча­ла зна­че­ние ис­ко­мой суммы для файла А, затем для файла B.

 

Пре­ду­пре­жде­ние: для об­ра­бот­ки файла B не сле­ду­ет ис­поль­зо­вать пе­ре­бор­ный ал­го­ритм, вы­чис­ля­ю­щий сумму для всех воз­мож­ных ва­ри­ан­тов, по­сколь­ку на­пи­сан­ная по та­ко­му ал­го­рит­му про­грам­ма будет вы­пол­нять­ся слиш­ком долго.

 

Ответ:

Спрятать решение

Ре­ше­ние.

По­сле­до­ва­тель­но счи­ты­вая дан­ные из файла, будем при­бав­лять к сумме ми­ни­маль­ное число в паре. Также за­ме­тим, что в слу­чае, если по­лу­чив­ше­е­ся в ре­зуль­та­те сум­ми­ро­ва­ние ми­ни­маль­ных чисел во всех парах число будет крат­но трём, до­ста­точ­но будет при­ба­вить к этой сумме ми­ни­маль­ную раз­ни­цу между ка­ки­ми-⁠либо двумя чис­ла­ми. Для этого при счи­ты­ва­нии пар по­ми­мо ми­ни­маль­но­го числа в каж­дой паре будем ис­кать ми­ни­маль­ную раз­ни­цу среди пар, не крат­ную трём.

 

При­ведём ре­ше­ние за­да­чи на языке Pascal.

var

x, y: integer;

n: integer;

sum: integer;

mindif: integer;

f: text;

begin

assign(f,'27_A.txt');

reset(f);

readln(f, n);

sum := 0;

mindif := 20001;

while not eof(f) do begin

readln(f, x, y);

if x < y then

sum := sum + x

else

sum := sum + y;

if (abs(x - y) < mindif) and (abs(x-y) mod 3 <> 0) then mindif := abs(x-y);

end;

if sum mod 3 <> 0 then

writeln(sum)

else

writeln(sum + mindif);

end.

 

В ре­зуль­та­те ра­бо­ты дан­но­го ал­го­рит­ма при вводе дан­ных из файла A ответ  — 67088, из файла B  — 200157478.

 

При­ведём ре­ше­ние Ро­ма­на Кня­зе­ва на языке Python.

f = open('27-A_demo.txt')

n = int(f.readline())

s = 0

minn = 20001

d = 0

for i in range(n):

x, y = map(int, f.readline().split())

s += min(x, y)

d = abs(x-y)

if d % 3 != 0:

minn = min(d, minn)

if s % 3 !=0:

print(s)

else:

print(s+minn)

f.close()

 

При­ме­ча­ние.

Путь к файлу не­об­хо­ди­мо ука­зать со­глас­но рас­по­ло­же­нию файла на Вашем ком­пью­те­ре.

 

При­ведём ре­ше­ние Артёма Гри­ди­на на языке Python.

f = open('27-A_demo.txt')

numbers = []

n = f.readline()

for m in f.readlines():

numbers.append(tuple(map(int, m.split())))

s = 0

for t in numbers:

if s+t[0]%3 != 0 and s+t[1]%3 != 0:

s+=min(t)

elif s+t[0]%3 != 0:

s+=t[0]

else:

s+=t[1]

print(s)


Аналоги к заданию № 27424: 27889 27890 Все

Раздел кодификатора ФИПИ: