ком2 #3

Open
karpov.v wants to merge 2 commits from ветка2 into main
Showing only changes of commit 07d75b901b - Show all commits

View File

@ -1,357 +1,504 @@
#include <stdio.h> // WindowsProject1.cpp : Определяет точку входа для приложения.
#include <Windows.h> //
#define NUM_ELEMENTS 10 #include "framework.h"
#include "WindowsProject1.h"
#define MAX_LOADSTRING 100
int arr[NUM_ELEMENTS]; // Глобальные переменные:
int n = 0; HINSTANCE hInst; // текущий экземпляр
void printElements() { WCHAR szTitle[MAX_LOADSTRING]; // Текст строки заголовка
printf("< "); WCHAR szWindowClass[MAX_LOADSTRING]; // имя класса главного окна
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf(">\n");
}
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 biggerten() {
int cnt = 0;
for (int i = 0; i < n; i++) {
if (arr[i] > 10) cnt++;
}
printf("%d элементов больше чем 10", cnt);
}
int FindLastEven() {
for (int i = n - 1; i > 0; i--) {
if (arr[i] % 2 == 0) return i;
}
}
int findIndexMin() {
int min = arr[0];
int inMin = 0;
for (int i = 1; i < n; i++) {
if (arr[i] < min) {
min = arr[i];
inMin = i;
}
}
return inMin;
}
int findIndexMax() {
int max = arr[0];
int inmx = 0;
for (int i = 1; i < n; i++) {
if (arr[i] > max) {
max = arr[i];
inmx = i;
}
}
return inmx;
}
void bred() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
arr[i] = -1 * arr[i];
}
}
}
void bred1() {
for (int i = 0; i < n; i++) {
if (arr[i] < 4) {
arr[i] = 4;
}
}
}
void bred2() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
arr[i] = 0;
}
}
}
int FindFirstEven() {
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
return i;
}
}
return -1;
}
void deletElement(int dl) {
for (int i = dl; i < n - 1; i++) {
arr[i] = arr[i + 1];
}
n--;
}
void insertElement(int ins, int val) {
for (int i = n; i > ins; i--) {
arr[i] = arr[i - 1];
}
n++;
arr[ins] = val;
}
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: x2 для последнего четного элемента\n");
printf("6: Сколько четных левее минимального\n");
printf("7: x10 для нечетных правее минимального\n");
printf("8: переставить месами min и max\n");
printf("9: Все четные элементы массива умножить на -1\n");
printf("10: Все элементы массива имеющие значения меньше 4 заменить на 4\n");
printf("11: Все четные элементы обнулить\n");
printf("12: Все элементы стоящие между максимальным и минимальным увеличить в 10 раз\n");
printf("13: Все элементы между первым и последним четным увеличить в 100 раз\n");
printf("14: удалить заданный элемент\n");
printf("15: Вставить новый элемент в заданное место\n");
printf("16: Удалить минимальный элемент\n");
printf("17: Перед минимальным элементом встваить ноль\n");
printf("18: Удалить все четные элементы\n");
printf("19: Продублировать все четные элементы\n");
printf("20: Добавить в начало элемент, равный минимальному\n");
printf("21: Удалить из массива все элементы, значение которых меньше 4\n");
printf("22: удалить первый из четных элементов\n");
printf("23: удалить четные элементы, стоящие после максимального\n");
printf("24: удалить самую длинную цепочку четных элементов\n");
printf("\n");
printf("0: Выйти из программы\n");
printf("Выбранная операция >>>>>> ");
scanf_s("%d", &item); // Отправить объявления функций, включенных в этот модуль кода:
switch (item) { ATOM MyRegisterClass(HINSTANCE hInstance);
case 1: BOOL InitInstance(HINSTANCE, int);
keyboardInput(); LRESULT CALLBACK WndProc(HWND, UINT, WPARAM, LPARAM);
break; INT_PTR CALLBACK About(HWND, UINT, WPARAM, LPARAM);
case 2: int APIENTRY wWinMain(_In_ HINSTANCE hInstance,
oddsX10(); _In_opt_ HINSTANCE hPrevInstance,
break; _In_ LPWSTR lpCmdLine,
_In_ int nCmdShow)
{
UNREFERENCED_PARAMETER(hPrevInstance);
UNREFERENCED_PARAMETER(lpCmdLine);
case 3: // TODO: Разместите код здесь.
{
int min = findMin();
printf("min = %d\n", min);
}
case 4:
biggerten();
break;
case 5:
{
int index = FindLastEven();
if (index >= 0) arr[index] *= 2;
}
case 6:
{
int indEx = findIndexMin();
printf("Индекс минимального элемента = %d\n", indEx);
int cnt = 0; // Инициализация глобальных строк
for (int i = 0; i < indEx; i++) { LoadStringW(hInstance, IDS_APP_TITLE, szTitle, MAX_LOADSTRING);
if (arr[i] % 2 == 0) cnt++; LoadStringW(hInstance, IDC_WINDOWSPROJECT1, szWindowClass, MAX_LOADSTRING);
} MyRegisterClass(hInstance);
printf("Левее минимального %d четных элементов\n", cnt);
} // Выполнить инициализацию приложения:
break; if (!InitInstance(hInstance, nCmdShow))
case 7:
{ {
int index = findIndexMin(); return FALSE;
printf("Индекс минимального элемента = %d\n", index);
for (int i = n; i > index; i--) {
if (arr[i] % 2 != 0) arr[i] *= 10;
} }
}
break; HACCEL hAccelTable = LoadAccelerators(hInstance, MAKEINTRESOURCE(IDC_WINDOWSPROJECT1));
case 8:
MSG msg;
// Цикл основного сообщения:
while (GetMessage(&msg, nullptr, 0, 0))
{ {
int indexmin = findIndexMin(); if (!TranslateAccelerator(msg.hwnd, hAccelTable, &msg))
printf("Индекс минимального элемента = %d\n", indexmin);
int indexmax = findIndexMax();
printf("Индекс максимального элемента = %d\n", indexmax);
int tmp = arr[indexmin];
arr[indexmin] = arr[indexmax];
arr[indexmax] = tmp;
}
break;
case 9:
bred();
break;
case 10:
bred1();
break;
case 11:
bred2();
break;
case 12:
{ {
int indexmin = findIndexMin(); TranslateMessage(&msg);
printf("Индекс минимального элемента = %d\n", indexmin); DispatchMessage(&msg);
int indexmax = findIndexMax();
printf("Индекс максимального элемента = %d\n", indexmax);
for (int i = indexmax + 1; i < indexmin; i++) {
arr[i] *= 10;
}
}
break;
case 13:
{
int indexf = FindFirstEven();
printf("Индекс минимального элемента = %d\n", indexf);
int indexl = FindLastEven();
printf("Индекс максимального элемента = %d\n", indexl);
for (int i = indexf + 1; i < indexl; i++) {
arr[i] *= 100;
}
}
break;
case 14:
{
int index;
printf("Индекс удаляемого элемента = ");
scanf_s("%d", &index);
deletElement(index);
}
break;
case 15:
{
int index;
int value;
printf("Перед каким элементом нужно вставить новый? Индекс = ");
scanf_s("%d", &index);
printf("Значение которое нужно вставить = ");
scanf_s("%d", &value);
insertElement(index, value);
}
break;
case 16:
{
int min = findIndexMin();
printf("min=%d\n", arr[min]);
deletElement(min);
}
break;
case 17:
{
int inmn = findIndexMin();
printf("Индекс минимального элемента = %d\n", inmn);
insertElement(inmn, 0);
}
break;
case 18:
{
for (int i = 0; i < n; i++) {
if (arr[i] % 2 == 0) {
deletElement(i);
i--;
} }
} }
return (int)msg.wParam;
} }
break;
case 19:
//
// ФУНКЦИЯ: MyRegisterClass()
//
// ЦЕЛЬ: Регистрирует класс окна.
//
ATOM MyRegisterClass(HINSTANCE hInstance)
{ {
for (int i = 0; i < n; i++) { WNDCLASSEXW wcex;
if (arr[i] % 2 == 0) {
insertElement(i, arr[i]); wcex.cbSize = sizeof(WNDCLASSEX);
wcex.style = CS_HREDRAW | CS_VREDRAW;
wcex.lpfnWndProc = WndProc;
wcex.cbClsExtra = 0;
wcex.cbWndExtra = 0;
wcex.hInstance = hInstance;
wcex.hIcon = LoadIcon(hInstance, MAKEINTRESOURCE(IDI_WINDOWSPROJECT1));
wcex.hCursor = LoadCursor(nullptr, IDC_ARROW);
wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW + 1);
wcex.lpszMenuName = MAKEINTRESOURCEW(IDC_WINDOWSPROJECT1);
wcex.lpszClassName = szWindowClass;
wcex.hIconSm = LoadIcon(wcex.hInstance, MAKEINTRESOURCE(IDI_SMALL));
return RegisterClassExW(&wcex);
}
//
// ФУНКЦИЯ: InitInstance(HINSTANCE, int)
//
// ЦЕЛЬ: Сохраняет маркер экземпляра и создает главное окно
//
// КОММЕНТАРИИ:
//
// В этой функции маркер экземпляра сохраняется в глобальной переменной, а также
// создается и выводится главное окно программы.
//
BOOL InitInstance(HINSTANCE hInstance, int nCmdShow)
{
hInst = hInstance; // Сохранить маркер экземпляра в глобальной переменной
HWND hWnd = CreateWindowW(szWindowClass, szTitle, WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, 0, CW_USEDEFAULT, 0, nullptr, nullptr, hInstance, nullptr);
if (!hWnd)
{
return FALSE;
}
ShowWindow(hWnd, nCmdShow);
UpdateWindow(hWnd);
return TRUE;
}
void Image0(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[4] = {
cx, cy + 20,
cx + 20, cy - 20,
cx - 20, cy - 20,
cx, cy + 20
};
Polyline(hdc, p, 4);
DeleteObject(hPen);
}
void Image1(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[4] = {
cx, cy - 20,
cx + 20, cy + 20,
cx - 20, cy + 20,
cx, cy - 20
};
Polyline(hdc, p, 4);
DeleteObject(hPen);
}
void Image2(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[5] = {
cx, cy - 20,
cx + 20, cy,
cx, cy + 20,
cx - 20 , cy ,
cx, cy - 20
};
Polyline(hdc, p, 5);
DeleteObject(hPen);
}
void Image3(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[5] = {
cx + 20, cy - 20,
cx , cy + 20,
cx - 20, cy - 20,
cx,cy,
cx + 20, cy - 20,
};
Polyline(hdc, p, 5);
DeleteObject(hPen);
}
void Image4(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[7] = {
cx - 20,cy,
cx - 20,cy - 20,
cx + 20,cy - 20,
cx,cy - 10,
cx + 20,cy,
cx - 20,cy,
cx - 20,cy + 20,
};
Polyline(hdc, p, 7);
DeleteObject(hPen);
}
void Image5(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[6] = {
cx - 20,cy - 20,
cx,cy,
cx + 20,cy - 20,
cx + 20,cy + 20,
cx - 20, cy + 20,
cx - 20,cy - 20,
};
Polyline(hdc, p, 6);
DeleteObject(hPen);
}
void Image6(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[10] = {
cx - 20,cy + 20,
cx - 20,cy - 20,
cx + 20,cy - 20,
cx + 20, cy + 20,
cx - 10, cy + 20,
cx - 10,cy - 10,
cx + 10,cy - 10,
cx + 10, cy + 10,
cx, cy + 10,
cx, cy,
};
Polyline(hdc, p, 10);
DeleteObject(hPen);
}
void Image7(HDC hdc, int cx, int cy, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT p[12] = {
cx ,cy + 20,
cx + 10, cy + 20,
cx + 10, cy,
cx + 20,cy,
cx + 20,cy - 10,
cx + 10,cy - 10,
cx + 5,cy - 40,
cx,cy - 10,
cx - 10,cy - 10,
cx - 10,cy,
cx,cy,
cx ,cy + 20,
};
Polyline(hdc, p, 12);
DeleteObject(hPen);
}
void Image8(HDC hdc, int x, int y, COLORREF color) {
HPEN hPen;
hPen = CreatePen(PS_SOLID, 2, color);
SelectObject(hdc, hPen);
POINT pt[8];
pt[0].x = 150;
pt[0].y = 50;
pt[1].x = 400;
pt[1].y = 50;
pt[2].x = 400;
pt[2].y = 300;
pt[3].x = 300;
pt[3].y = 300;
pt[4].x = 300;
pt[4].y = 100;
pt[5].x = 250;
pt[5].y = 100;
pt[6].x = 250;
pt[6].y = 300;
pt[7].x = 150;
pt[7].y = 300;
Polygon(hdc, pt, 8);
}
//
// ФУНКЦИЯ: WndProc(HWND, UINT, WPARAM, LPARAM)
//
// ЦЕЛЬ: Обрабатывает сообщения в главном окне.
//
// WM_COMMAND - обработать меню приложения
// WM_PAINT - Отрисовка главного окна
// WM_DESTROY - отправить сообщение о выходе и вернуться
//
//
enum Modes {
image0,
image1,
image1_line,
image1_with_colors,
image2,
image2_with_colors,
image3,
image3_lines,
image3_with_colors,
image4,
image4_lines,
image4_with_colors,
image5,
image6,
image7,
image8,
mode_none
};
enum Modes mode = image0;
void Picture0(HDC hdc) {
Image0(hdc, 40, 40, RGB(255, 0, 0)); // Код был в лекции
Image0(hdc, 140, 40, RGB(255, 0, 0));
Image0(hdc, 240, 40, RGB(255, 0, 0));
Image0(hdc, 240, 240, RGB(255, 0, 0));
Image0(hdc, 40, 240, RGB(255, 0, 0));
}
void Picture1(HDC hdc) {
Image1(hdc, 40, 40, RGB(255, 0, 0));
Image1(hdc, 140, 40, RGB(255, 0, 0));
Image1(hdc, 240, 40, RGB(255, 0, 0));
Image1(hdc, 240, 240, RGB(255, 0, 0));
Image1(hdc, 40, 240, RGB(255, 0, 0));
}
void Picture2(HDC hdc) {
Image2(hdc, 40, 40, RGB(255, 0, 0));
Image2(hdc, 140, 40, RGB(255, 0, 0));
Image2(hdc, 240, 40, RGB(255, 0, 0));
Image2(hdc, 240, 240, RGB(255, 0, 0));
Image2(hdc, 40, 240, RGB(255, 0, 0));
}
void Picture3(HDC hdc) {
Image3(hdc, 40, 40, RGB(255, 0, 0));
Image3(hdc, 140, 40, RGB(255, 0, 0));
Image3(hdc, 240, 40, RGB(255, 0, 0));
Image3(hdc, 240, 240, RGB(255, 0, 0));
Image3(hdc, 40, 240, RGB(255, 0, 0));
}
void Picture4(HDC hdc) {
Image4(hdc, 40, 40, RGB(255, 0, 0));
Image4(hdc, 140, 40, RGB(255, 0, 0));
Image4(hdc, 240, 40, RGB(255, 0, 0));
Image4(hdc, 240, 240, RGB(255, 0, 0));
Image4(hdc, 40, 240, RGB(255, 0, 0));
}
void PictureFLineY(HDC hdc, void(*pfImage)(HDC hdc, int cx, int cy, COLORREF color)) {
short x = 40;
short y = 40;
char i = 0;
while (i < 6) {
pfImage(hdc, x, y, RGB(255, 0, 0));
y += 50;
i++; i++;
} }
} }
void PictureFColorLines(HDC hdc, void(*pfImage)(HDC hdc, int cx, int cy, COLORREF color)) {
unsigned char r = 255;
unsigned char g = 0;
short y = 40;
char i = 0;
while (i < 6) {
short x = 40;
char j = 0;
unsigned char b = 0;
while (j < 10) {
pfImage(hdc, x, y, RGB(r, g, b));
x += 50;
j++;
b += 25;
} }
break; y += 50;
case 20: i++;
g += 50;
}
}
void PictureFLines(HDC hdc, void(*pfImage)(HDC hdc, int cx, int cy, COLORREF color)) {
short y = 40;
char i = 0;
while (i < 6) {
short x = 40;
char j = 0;
while (j < 10) {
pfImage(hdc, x, y, RGB(255, 0, 0));
x += 50;
j++;
}
y += 50;
i++;
}
}
void PictureFLineX(HDC hdc, void(*per)(HDC hdc, int cx, int cy, COLORREF color)) {
short x = 40;
short y = 40;
char j = 0;
while (j < 10) {
per(hdc, x, y, RGB(255, 0, 0));
x += 50;
j++;
}
}
LRESULT CALLBACK WndProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{ {
int inmn = findIndexMin(); switch (message)
printf("Индекс минимального элемента = %d\n", inmn);
insertElement(0, arr[inmn]);
}
break;
case 21:
{ {
for (int i = 0; i < n; i++) { case WM_COMMAND:
if (arr[i] < 4) {
deletElement(i);
i--;
}
}
}
break;
case 22:
{ {
int indexf = FindFirstEven(); int wmId = LOWORD(wParam);
printf("Индекс минимального элемента = %d\n", indexf); // Разобрать выбор в меню:
deletElement(indexf); switch (wmId)
}
break;
case 23:
{ {
int indexmax = findIndexMax(); case IDM_ABOUT:
printf("Индекс максимального элемента = %d\n", indexmax); DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
for (int i = indexmax + 1; i < n; i++) { break;
if (arr[i] % 2 == 0) { case IDM_EXIT:
deletElement(i); DestroyWindow(hWnd);
i--; break;
} default:
return DefWindowProc(hWnd, message, wParam, lParam);
} }
} }
break; break;
case 24: case WM_PAINT:
{ {
int teklen = 0, teknach = -1; PAINTSTRUCT ps;
int maxlen = 0, maxnach = -1; HDC hdc = BeginPaint(hWnd, &ps);
for (int i = 0; i < n; i++) { // TODO: Добавьте сюда любой код прорисовки, использующий HDC...
if (arr[i] % 2 == 0) { switch (mode) {
if (teklen == 0) { case image0:
teknach = i; Picture0(hdc); // Код выше
break;
case image1:
Picture1(hdc); // Код выше
break;
case image1_line:
PictureFLineY(hdc, Image1); // Код был в лекции
break;
case image1_with_colors:
PictureFColorLines(hdc, Image1); // Код был в лекции
break;
case image2:
Picture2(hdc);
break;
case image2_with_colors:
PictureFColorLines(hdc, Image2); // Код был в лекции
break;
case image3:
PictureFLineX(hdc, Image3);
break;
case image3_lines:
PictureFLines(hdc, Image3);
break;
case image3_with_colors:
PictureFColorLines(hdc, Image3); // Код был в лекции
break;
case image4:
PictureFLineX(hdc, Image4);
break;
case image4_lines:
PictureFLines(hdc, Image4);
break;
case image4_with_colors:
PictureFColorLines(hdc, Image4); // Код был в лекции
break;
case image5:
Image5(hdc, 40, 40, RGB(255, 0, 0));
break;
case image6:
Image6(hdc, 40, 40, RGB(255, 0, 0));
break;
case image7:
Image7(hdc, 40, 40, RGB(255, 0, 0));
break;
case image8:
Image8(hdc, 40, 40, RGB(255, 0, 0));
break;
} }
teklen++;
EndPaint(hWnd, &ps);
} }
else { break;
if (teklen > maxlen) { case WM_KEYDOWN:
maxlen = teklen; mode = (enum Modes)(mode + 1); // переключение на следующий режим
maxnach = teknach; if (mode == mode_none) mode = image0; // если режимы закончились - начинаем заново
} InvalidateRect(hWnd, NULL, TRUE);
teklen = 0; break;
} case WM_DESTROY:
} PostQuitMessage(0);
if (teklen > maxlen) { break;
maxlen = teklen; default:
maxnach = teknach; return DefWindowProc(hWnd, message, wParam, lParam);
}
if (maxnach != -1) {
for (int i = 0; i < maxlen; i++) {
deletElement(maxnach);
} }
return 0;
} }
// Обработчик сообщений для окна "О программе".
INT_PTR CALLBACK About(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
UNREFERENCED_PARAMETER(lParam);
switch (message)
{
case WM_INITDIALOG:
return (INT_PTR)TRUE;
case WM_COMMAND:
if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
{
EndDialog(hDlg, LOWORD(wParam));
return (INT_PTR)TRUE;
} }
break; break;
} }
} while (item != 0); return (INT_PTR)FALSE;
} }