• Предмет: Информатика
  • Автор: meecapri228
  • Вопрос задан 2 года назад

С++

Сокращение последовательности

Дана последовательность натуральных чисел. Найдите наибольший общий делитель всех элементов последовательности и сократите все её члены на него.

Решение оформите в виде функции bool isDivisor(vector &A, int d), проверяющей является ли число d общим делителем последовательности, и функции void reduction(vector &A), которая находит наибольший общий делитель и сокращает все члены последовательности на него.

#include
#include
using namespace std;
bool isDivisor(vector &A, int d)
void reduction(vector &A)

#место для кода

int main()
{
int n;
cin >> n;
vector A(n);
for (int i = 0; i < n; ++i){
cin >> A[i];
}
reduction(A);
for (int i = 0; i < A.size(); ++i){
cout << A[i] << " ";
}
return 0;
}


ilai2541358: Ватцап напиши +79169835516
ilai2541358: Ой
ilai2541358: Это не мой телефон ^)
kykareeky: хпхпх
ilai2541358: Лан это мой телефон
ilai2541358: За сегодня 12 заданий осилил..
kykareeky: ого... молодец! а сколько ты занимаешься... или как
kykareeky: Не подскажешь, как первое сделать? Я так понимаю, что там должна быть какая-то мат. формула?
ilai2541358: В ватцап
ilai2541358: Пиши

Ответы

Ответ дал: kykareeky
1

{int g = 0;

  for (int i = 0; i < A.size(); i++) {

      if (A[i]%d == 0) g = 1;

      else {

      g = 0;

      break;}}

  if (g == 1) return true;

  return false;}

void reduction(vector<int> &A) {

  int d = 1;

  for (int i = A[0]; i >= 2; i--) {

      if (isDivisor(A,i)) {

          d = i;

          break;}}

  for (int i = 0; i < A.size(); i++) {

      A[i] = A[i] / d;}}

а ты решил 3ю и 7ую задачи? можешь скинуть?


ilai2541358: Я решил
ilai2541358: https://znanija.com/task/43825184
ilai2541358: На 3й
tamarakirkinadze: Ребят, вы решили 9,10?
ilai2541358: Да
kykareeky: ребят вы решили хоть что-то из нового блока?
ilai2541358: Да
ilai2541358: 8 задач
kykareeky: помоги, пожалуйста, я уже голову сломала....
kykareeky: умоляю
Ответ дал: ilai2541358
1

Ответ:

Объяснение:

#include <iostream>

#include <vector>

using namespace std;

bool isDivisor(vector<int> &A, int d) {

int g = 0;

for (int i = 0; i < A.size(); i++) {

if (A[i]%d == 0) g = 1; //если все элементы делятся на d то g сохранит единицу

else {

g = 0;

break; //если хотя бы один не поделился то прекращаем цикл и начинаем другой

}

}

if (g == 1) return true; //правда если все делятся

return false; //ложь если хотя бы один не поделился

}

void reduction(vector<int> &A) {

int d = 1; //НОД

for (int i = A[0]; i >= 2; i--) {

if (isDivisor(A,i)) {

d = i;

break; //НОД, если все элементы делятся на него

}

}

for (int i = 0; i < A.size(); i++) {

A[i] = A[i] / d; //делим все элементы на НОД

}

}

int main() {

int n;

cin >> n;

vector<int> A(n);

for (int i = 0; i < n; ++i){

cin >> A[i];

}

reduction(A);

for (int i = 0; i < A.size(); ++i){

cout << A[i] << " ";

}

return 0;

}

Вас заинтересует