294 lines
6.3 KiB
C++
294 lines
6.3 KiB
C++
|
#include <stdio.h>
|
|||
|
#include <Windows.h>
|
|||
|
|
|||
|
#define NUM_ELEMENTS 10
|
|||
|
|
|||
|
int arr[NUM_ELEMENTS] = { 7, 3, 6, 1, 9, 5, 2, 4, 8 }; // Исходный массив для примера
|
|||
|
int n = 9;
|
|||
|
|
|||
|
void printElements() {
|
|||
|
printf("< ");
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
printf("%d ", arr[i]);
|
|||
|
}
|
|||
|
printf(">\n");
|
|||
|
}
|
|||
|
|
|||
|
void addElement(int value) {
|
|||
|
arr[n++] = value;
|
|||
|
|
|||
|
}
|
|||
|
|
|||
|
void keyboardInput() {
|
|||
|
printf("n = ");
|
|||
|
scanf_s("%d", &n);
|
|||
|
|
|||
|
printf("input %d vales: ", n);
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
scanf_s("&d", &arr[i]);
|
|||
|
}
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
void oddsX10() {
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
if (arr[i] % 2 != 0) {
|
|||
|
arr[i] = arr[i] * 10;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
void odds() {
|
|||
|
int lastIn = -1;
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
if (arr[i] % 2 != 0) {
|
|||
|
lastIn = i;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
if (lastIn != -1) {
|
|||
|
n++;
|
|||
|
for (int i = n - 1; i > lastIn + 1; i--) {
|
|||
|
arr[i] = arr[i - 1];
|
|||
|
}
|
|||
|
arr[lastIn + 1] = 0;
|
|||
|
printElements();
|
|||
|
}
|
|||
|
}
|
|||
|
int findMin() {
|
|||
|
int min = arr[0];
|
|||
|
for (int i = 1; i < n; i++) {
|
|||
|
if (arr[i] < min) {
|
|||
|
min = arr[i];
|
|||
|
}
|
|||
|
}
|
|||
|
return min;
|
|||
|
}
|
|||
|
|
|||
|
int tenElement() {
|
|||
|
int count = 0;
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
if (arr[i] > 10) {
|
|||
|
count++;
|
|||
|
}
|
|||
|
}
|
|||
|
return count;
|
|||
|
}
|
|||
|
int findLastEven() {
|
|||
|
for (int i = n - 1; i >= 0; i--) {
|
|||
|
if (arr[i] % 2 == 0) {
|
|||
|
return i;
|
|||
|
}
|
|||
|
}
|
|||
|
return -1;
|
|||
|
}
|
|||
|
|
|||
|
int findIndexMin() {
|
|||
|
int minIndex = 0;
|
|||
|
for (int i = 1; i < n; i++) {
|
|||
|
if (arr[i] < arr[minIndex]) {
|
|||
|
minIndex = i;
|
|||
|
}
|
|||
|
}
|
|||
|
return minIndex;
|
|||
|
}
|
|||
|
|
|||
|
void negateEvenElements() {
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
if (arr[i] % 2 == 0) {
|
|||
|
arr[i] = arr[i] * -1;
|
|||
|
}
|
|||
|
}
|
|||
|
printf("Массив после умножения четных элементов на -1: ");
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
void replaceLessThanFour() {
|
|||
|
for (int i = 0; i < n; i++) {
|
|||
|
if (arr[i] < 4) {
|
|||
|
arr[i] = 4;
|
|||
|
}
|
|||
|
}
|
|||
|
printf("Массив после замены значений < 4 на 4: ");
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
int findIndexMax() {
|
|||
|
int maxIndex = 0;
|
|||
|
for (int i = 1; i < n; i++) {
|
|||
|
if (arr[i] > arr[maxIndex]) {
|
|||
|
maxIndex = i;
|
|||
|
}
|
|||
|
}
|
|||
|
return maxIndex;
|
|||
|
}
|
|||
|
|
|||
|
void replaceBeforeMaxWithZero() {
|
|||
|
int maxIndex = findIndexMax();
|
|||
|
for (int i = 0; i < maxIndex; i++) {
|
|||
|
arr[i] = 0;
|
|||
|
}
|
|||
|
printf("Массив после замены элементов перед максимальным на 0: ");
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
void deleteElement(int index) {
|
|||
|
if (index < 0 || index >= n) {
|
|||
|
printf("Неверный индекс!\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
for (int i = index; i < n - 1; i++) {
|
|||
|
arr[i] = arr[i + 1];
|
|||
|
}
|
|||
|
|
|||
|
n--;
|
|||
|
printf("Массив после удаления элемента на индексе %d: ", index);
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
void insertElement(int index, int value) {
|
|||
|
if (index < 0 || index >= n || n >= NUM_ELEMENTS) {
|
|||
|
printf("Неверный индекс!\n");
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
for (int i = n; i > index; i--) {
|
|||
|
arr[i] = arr[i - 1];
|
|||
|
}
|
|||
|
arr[index] = value;
|
|||
|
n++;
|
|||
|
printf("Массив после вставки элемента %d на индекс %d: ", value, index);
|
|||
|
printElements();
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
void main() {
|
|||
|
SetConsoleCP(1251);
|
|||
|
SetConsoleOutputCP(1251);
|
|||
|
int item;
|
|||
|
do {
|
|||
|
printf("\n");
|
|||
|
printf("------------------------------\n");
|
|||
|
printf("Содержимое массива:");
|
|||
|
printElements();
|
|||
|
printf("Выберите нужную вам операцию:\n");
|
|||
|
printf("1: Ввести с клавиатуры массив\n");
|
|||
|
printf("2: x10 для всех нечетных элементов\n");
|
|||
|
printf("3: Найти минимальный элемент\n");
|
|||
|
printf("4: Сколько элементов > 10 \n");
|
|||
|
printf("5: Удвоение последнего четного элемента\n");
|
|||
|
printf("6: Сколько четных левее минимального\n");
|
|||
|
printf("7: Все четные элементы массива умножить на -1\n");
|
|||
|
printf("8: Массив после замены значений < 4 на 4\n");
|
|||
|
printf("9: Массив после замены элементов перед максимальным на 0\n");
|
|||
|
printf("10: Удаление элемента по идексу\n");
|
|||
|
printf("11: Добавление элемента по индексу\n");
|
|||
|
printf("12: Удаление минимального элемента\n");
|
|||
|
printf("13: 0 перед минимальным элемментом\n");
|
|||
|
printf("14: После последнего нечетного элемента вставить 0\n");
|
|||
|
printf("\n");
|
|||
|
printf("0: Выйти из программы\n");
|
|||
|
printf("Выбранная операция >>>>>> ");
|
|||
|
|
|||
|
scanf_s("%d", &item);
|
|||
|
switch (item) {
|
|||
|
case 1:
|
|||
|
keyboardInput();
|
|||
|
break;
|
|||
|
|
|||
|
case 2:
|
|||
|
oddsX10();
|
|||
|
break;
|
|||
|
|
|||
|
case 3:
|
|||
|
{
|
|||
|
int min = findMin();
|
|||
|
printf("min = %d\n", min);
|
|||
|
}
|
|||
|
break;
|
|||
|
|
|||
|
case 4: {
|
|||
|
int count = tenElement();
|
|||
|
printf("Элементов больше 10: %d\n", count);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 5: {
|
|||
|
int index = findLastEven();
|
|||
|
if (index >= 0) {
|
|||
|
arr[index] *= 2;
|
|||
|
printf("Последний четный элемент удвоен: %d\n", arr[index]);
|
|||
|
}
|
|||
|
else {
|
|||
|
printf("Четных элементов в массиве нет.\n");
|
|||
|
}
|
|||
|
}
|
|||
|
break;
|
|||
|
case 6:{
|
|||
|
|
|||
|
int index = findIndexMin();
|
|||
|
printf("Индекс минимального элемента = %d\n", index);
|
|||
|
|
|||
|
int cnt = 0;
|
|||
|
for (int i = 0; i < index; i++) {
|
|||
|
if (arr[i] % 2 == 0) {
|
|||
|
cnt++;
|
|||
|
}
|
|||
|
}
|
|||
|
printf("Левее минимального %d четных элементов\n", cnt);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 7:
|
|||
|
negateEvenElements();
|
|||
|
break;
|
|||
|
case 8:
|
|||
|
replaceLessThanFour();
|
|||
|
break;
|
|||
|
case 9:
|
|||
|
replaceBeforeMaxWithZero();
|
|||
|
break;
|
|||
|
case 10:
|
|||
|
{
|
|||
|
int index;
|
|||
|
printf("Введите элемент для удаления: ");
|
|||
|
scanf_s("%d", &index);
|
|||
|
deleteElement(index);
|
|||
|
break;
|
|||
|
}
|
|||
|
case 11:
|
|||
|
{
|
|||
|
printf("Индекс: ");
|
|||
|
int index;
|
|||
|
scanf_s("%d", &index);
|
|||
|
printf("Значение, которое нужно вставвить: ");
|
|||
|
int value;
|
|||
|
scanf_s("%d", &value);
|
|||
|
insertElement(index, value);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 12:
|
|||
|
{
|
|||
|
int minIndex = findIndexMin();
|
|||
|
printf("Минимальный элемент: %d\n", arr[minIndex]);
|
|||
|
deleteElement(minIndex);
|
|||
|
printElements();
|
|||
|
}
|
|||
|
break;
|
|||
|
case 13: {
|
|||
|
int Indexmin = findIndexMin();
|
|||
|
printf("Индекс минимального элемента = %d\n", Indexmin);
|
|||
|
insertElement(Indexmin, 0);
|
|||
|
}
|
|||
|
break;
|
|||
|
case 14:
|
|||
|
odds();
|
|||
|
break;
|
|||
|
}
|
|||
|
|
|||
|
|
|||
|
} while (item != 0);
|
|||
|
}
|