Vikkitrip
?>

Задача Дроби-2 N дробей заданы своими числителями и знаменателями. Сколько дробей из этого списка различны? Обратите внимание, что не все дроби являются правильными — у некоторых числитель больше знаменателя, а у некоторых числитель и знаменатель не являются взаимно простыми числами. Формат входных данных Первая строка входного файла содержит величину N (1 ≤ N ≤ 105, для 50 % тестов эта величина не превосходит 1000 Далее следуют N строк, в каждой из которых записаны два целых числа A и B (−109 ≤ A ≤ 109, 1 ≤ B ≤ 109, для 90 % тестов −105 ≤ A ≤ 105, 1 ≤ B ≤ 105) — числитель и знаменатель очередной дроби. Формат выходных данных Выведите ответ на задачу — количество различных дробей.

Информатика

Ответы

Голубева1440
1. "Школьное" решение

// PascalABC.NET 3.0, сборка 1073
const
  sb='bcdfgjklmnpqrstvwxz';
  s='Computer programming is a process of computer programs creation';
var
  i,n:integer;
  s1,sn,t:string;
begin
  i:=1;
  while s[i]<>' ' do Inc(i);
  s1:=Copy(s,1,i-1);
  n:=Length(s); i:=n;
  while s[i]<>' ' do Dec(i);
  sn:=Copy(s,i+1,n-i);
  t:='';
  for i:=1 to Length(s1) do
    if Pos(s1[i],sb)>0 then t:=t+s1[i];
  s1:=t;
  t:='';
  for i:=1 to Length(sn) do
    if Pos(sn[i],sb)>0 then t:=t+sn[i];
  sn:=t;
  t:='';
  for i:=1 to Length(s1) do
    if Pos(s1[i],sn)>0 then
      if Pos(s1[i],t)=0 then t:=t+s1[i];
  for i:=1 to Length(t) do Write(t[i],' ');
  Writeln
end.
 
Тестовый прогон:
t r

2. "Нормальное" решение

// PascalABC.NET 3.0, сборка 1073
const
  sb='bcdfgjklmnpqrstvwxz';
  s='Computer programming is a process of computer programs creation';
begin
  var a:=s.ToWords(' ');
  a[0].Intersect(a[a.Length-1]).Where(x->Pos(x,sb)>0).Println(',')
end.

Тестовый прогон:
t,r

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

Задача Дроби-2 N дробей заданы своими числителями и знаменателями. Сколько дробей из этого списка различны? Обратите внимание, что не все дроби являются правильными — у некоторых числитель больше знаменателя, а у некоторых числитель и знаменатель не являются взаимно простыми числами. Формат входных данных Первая строка входного файла содержит величину N (1 ≤ N ≤ 105, для 50 % тестов эта величина не превосходит 1000 Далее следуют N строк, в каждой из которых записаны два целых числа A и B (−109 ≤ A ≤ 109, 1 ≤ B ≤ 109, для 90 % тестов −105 ≤ A ≤ 105, 1 ≤ B ≤ 105) — числитель и знаменатель очередной дроби. Формат выходных данных Выведите ответ на задачу — количество различных дробей.
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

petrovichvit2933
bulenbeiser
Klicheva_Ermachenkova1536
tanyaandreeva728
sunrise
Olga-Borisovna
Marinanagornyak
sevro3038
Михаил736
modellisimo-a
Yeremeev
steff77
gabbro19975650
MariyaKhanbalaeva585
oloinics