на языке С++. Составить программу, которая заполнит массив, состоящий из 20-ти элементов, целыми случайными числами из диапазона от 0 до 10. На экран выведет элементы массива со 2-го по 11-й в виде: x[1]=… x[2]=… … x[10]=…
То есть, в данном условии допускается 4 исхода событий
S действительно меньше двух и T действительно меньше пяти (выполняются оба условия)S меньше двух, но T больше или равно пяти (то есть, одно условие выполняется, а второе не выполняется)S больше или равно двум, а T меньше пяти (то есть, первое условие не выполняется, но второе верно)S больше или равно двум и T больше или равно пяти (оба условия оказались ложными)
Если у вас получился один из вариантов 1,2,3, то условие (S<2 или T<5) будет иметь итоговый вердикт ВЕРНО
Если у вас получился вариант №4, то условие будет иметь итоговый вердикт НЕВЕРНО
К моему ответу прикрепляю изображение с объяснением этого правила в алгебре логики.
Надеюсь . Если остались вопросы - задавайте в ЛС или в комментарии к ответу. Удачи!
#include <iostream> #include <string> #include <cstdlib> #include <algorithm> using namespace std; typedef unsigned short int USI;
int* fillArray(string name, int s); int maxArray(int[], int s); bool isPrime(int); void deleteAllEqualTo(int[], int s, int value); float averageOfPositive(int[], int s); void printArray(int[], int s);
bool sortByDescAbs(int i, int j) { return abs(i) > abs(j); }
int main() { setlocale(LC_ALL, "Russian"); USI n; cout << "n = "; cin >> n; int* z = fillArray("z", n); int max = maxArray(z, n); if ( isPrime(max) ) { deleteAllEqualTo(z, n, max); } float avg = averageOfPositive(z, n); cout << "среднее: " << avg << '\n'; sort(z, z + n, sortByDescAbs); cout << "z[" << n << "]: "; printArray(z, n); return 0; }
int* fillArray(string name, int s) { int array[s]; for (int i = 0; i < s; i++) { cout << name << "[" << i << "] = "; cin >> array[i]; } return array; }
int maxArray(int a[], int s) { int max = a[0]; for (int i = 1; i < s; i++) { if (a[i] > max) max = a[i]; } return max; }
bool isPrime(int n) { if (n < 2) return false; if (n == 2) return true; if (n % 2 == 0) return false; for (int i = 3; (i*i) <= n; i += 2) { if (n % i == 0 ) return false; } return true; }
void deleteAllEqualTo(int a[], int s, int value) { for (int i = 0; i < s; i++) { if (a[i] == value) a[i] = 0; } }
float averageOfPositive(int a[], int s) { unsigned int sum = 0, count = 0; for (int i = 0; i < s; i++) { if (a[i] > 0) { sum += a[i]; count++; } } return (sum / count); }
void printArray(int a[], int s) { for (int i = 0; i < s; i++) { cout << a[i] << ' '; } }
Объяснение:
У вас записано S<2 или T<5
Это читается так: S меньше двух или T меньше пяти
То есть, в данном условии допускается 4 исхода событий
S действительно меньше двух и T действительно меньше пяти (выполняются оба условия)S меньше двух, но T больше или равно пяти (то есть, одно условие выполняется, а второе не выполняется)S больше или равно двум, а T меньше пяти (то есть, первое условие не выполняется, но второе верно)S больше или равно двум и T больше или равно пяти (оба условия оказались ложными)Если у вас получился один из вариантов 1,2,3, то условие (S<2 или T<5) будет иметь итоговый вердикт ВЕРНО
Если у вас получился вариант №4, то условие будет иметь итоговый вердикт НЕВЕРНО
К моему ответу прикрепляю изображение с объяснением этого правила в алгебре логики.
Надеюсь . Если остались вопросы - задавайте в ЛС или в комментарии к ответу. Удачи!