2 #3

Open
nikidzu wants to merge 2 commits from vetka2 into main

View File

@ -1,66 +1,252 @@
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdio.h>
#include <Windows.h>
#define NUM_ELEMENTS 10
int a[1000]; //массив. 1000 - максимально допустимое количество элементов
int n; // Реальное количество элементов в массиве
int arr[NUM_ELEMENTS];
int n = 0;
void printElements();
void keyboardInput();
void oddsX10();
int findMin();
int count10();
void findLastEven();
int findIndexMin();
void findEven();
void Less4();
void NotEven1V2();
void deleteElement();
void insertElement();
void deletemin();
void Infrontofmin();
void DeleteLastEven();
void Load() {
// Открытие входного файла
FILE* fin = fopen("C:\\Users\\ПК\\Desktop\\in1.txt", "rt");
if (fin == NULL) {
printf("Входной файл не найден\n");
return;
}
// Загрузка массива из входного файла
fscanf(fin, "%d", &n);
for (int i = 0; i < n; i++) {
fscanf(fin, "%d", &a[i]);
}
// Закрытие входного файла
fclose(fin);
}
void SaveResult() {
// Вычисление среднего арифметического
float sa = 0;
float s = 0;
for (int i = 0; i < n; i++) {
s += a[i];
}
sa = s / n;
// Выяснение, сколько элементов больше ср арифметического
int m = 0;
for (int i = 0; i < n; i++) {
if (a[i] > sa) {
m++;
}
}
// Открытие выходного файла
FILE* fout = fopen("C:\\Users\\ПК\\Desktop\\out1.txt", "wt");
if (fout == NULL) {
printf("Выходной файл не найден\n");
return;
}
// Сохранение элементов больших ср арифметического
fprintf(fout, "%d\n", m);
for (int i = 0; i < n; i++) {
if (a[i] > sa) {
fprintf(fout, "%d ", a[i]);
}
}
// Закрытие файла
fclose(fout);
}
void main() {
SetConsoleCP(1251);
SetConsoleOutputCP(1251);
printf("Hello! It is Task1!\n");
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: Найти последний чётный элемент и умножить его на 2\n");
printf("6: Найти индекс минимального элемента и количество чётных после него\n");
printf("7: Умножить все элементы в массиве на -1\n");
printf("8: Все элементы массива имеющие значения меньше 4 заменить на 4\n");
printf("9: Заменить все нечётные элементы на 1\n");
printf("11: Удаление заданного элемента массива\n");
printf("12: Вставка нового элемента по индексу\n");
printf("13: Удалить минимальный элемент\n");
printf("14: Перед минимальным элементом поставить 0\n");
printf("15: Из массива удалить первый из чётных элементов\n");
printf("\n");
printf("0: Выйти из программы\n");
printf("Выбранная операция >>>>>> ");
scanf_s("%d", &item);
switch (item) {
case 1:
keyboardInput();
break;
Load();
SaveResult();
case 2:
oddsX10();
break;
case 3:
{
int min = findMin();
printf("min = %d\n", min);
}
break;
case 4:
{
int ctn = count10();
printf("cnt=%d\n", ctn);
}
break;
case 5:
findLastEven();
break;
case 6:
{
int indexMin = findIndexMin();
printf("Индекс минимального элемента=%d\n", indexMin);
int cnt = 0;
for (int i = 0; i < indexMin; i++) {
if (arr[i] % 2 == 0) {
cnt++;
}
}
printf("Левее минимального %d чётных элементов\n", cnt);
}
break;
case 7:
findEven();
break;
case 8:
Less4();
break;
case 9:
NotEven1V2();
break;
case 11:
deleteElement();
break;
case 12:
insertElement();
break;
case 13:
deletemin();
break;
case 14:
Infrontofmin();
break;
case 15:
DeleteLastEven();
break;
}
} while (item != 0);
}
void keyboardInput() {
printf("n=");
scanf_s("%d", &n);
printf("input %d values: ", n);
for (int i = 0; i < n; i++) {
scanf_s("%d", &arr[i]);
}
}
void oddsX10() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 1) {
arr[i] = arr[i] * 10;
}
}
}
int findMin() {
int min = arr[0];
for (int i = 1; i < n; i++) {
if (arr[i] < min) {
min = arr[i];
}
}
return min;
}
void printElements() {
printf("< ");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf(">\n");
}
int count10() {
int cnt = 0;
for (int i = 0; i < n; i++) {
if (arr[i] > 10) {
cnt++;
}
}
return cnt;
}
int findIndexMin() {
int min = arr[0];
int indexMin = 0;
for (int i = 1; i < n; i++) {
if (arr[i] < min) {
min = arr[i];
indexMin = i;
}
}
return indexMin;
}
void findEven() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
arr[i] = arr[i] * -1;
}
}
}
void Less4() {
for (int i = 0; i < n; i++) {
if (arr[i] < 4) {
arr[i] = 4;
}
}
}
void NotEven1V2() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 1) {
arr[i] = 1;
}
}
}
void deleteElement() {
printf("Индекс удаляемого элемента = ");
int index;
scanf_s("%d", &index);
for (int i = index; i < n - 1; i++) {
arr[i] = arr[i + 1];
}
n--;
}
void insertElement() {
printf("Перед каким элементов нужно вставить новый? Индекс= ");
int index;
scanf_s("%d", &index);
printf("Значение,которое нужно вставить= ");
int value;
scanf_s("%d", &value);
for (int i = n; i > index; i--) {
arr[i] = arr[i - 1];
}
n++;
arr[index] = value;
}
void deletemin() {
int Indexmin;
Indexmin = findIndexMin();
for (int i = Indexmin; i < n - 1; i++) {
arr[i] = arr[i + 1];
}
n--;
}
void Infrontofmin() {
int Indexmin;
Indexmin = findIndexMin();
int value;
value = 0;
for (int i = n; i > Indexmin; i--) {
arr[i] = arr[i - 1];
}
n++;
arr[Indexmin] = value;
}
void findLastEven() {
int index = 0;
int value = 0;
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
index = i;
value = 2 * (arr[i]);
}
}
arr[index] = value;
}
void DeleteLastEven() {
int index = 0;
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
index = i;
}
}
for (int i = index; i < n - 1; i++) {
arr[i] = arr[i + 1];
}
n--;
}