ком2 #3
@ -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)
|
||||||
|
{
|
||||||
|
WNDCLASSEXW wcex;
|
||||||
|
|
||||||
|
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)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < n; i++) {
|
return FALSE;
|
||||||
if (arr[i] % 2 == 0) {
|
}
|
||||||
insertElement(i, arr[i]);
|
|
||||||
|
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++;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 20:
|
|
||||||
{
|
|
||||||
int inmn = findIndexMin();
|
|
||||||
printf("Индекс минимального элемента = %d\n", inmn);
|
|
||||||
insertElement(0, arr[inmn]);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 21:
|
|
||||||
{
|
|
||||||
for (int i = 0; i < n; i++) {
|
|
||||||
if (arr[i] < 4) {
|
|
||||||
deletElement(i);
|
|
||||||
i--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 22:
|
|
||||||
{
|
|
||||||
int indexf = FindFirstEven();
|
|
||||||
printf("Индекс минимального элемента = %d\n", indexf);
|
|
||||||
deletElement(indexf);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 23:
|
|
||||||
{
|
|
||||||
int indexmax = findIndexMax();
|
|
||||||
printf("Индекс максимального элемента = %d\n", indexmax);
|
|
||||||
for (int i = indexmax + 1; i < n; i++) {
|
|
||||||
if (arr[i] % 2 == 0) {
|
|
||||||
deletElement(i);
|
|
||||||
i--;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 24:
|
|
||||||
{
|
|
||||||
int teklen = 0, teknach = -1;
|
|
||||||
int maxlen = 0, maxnach = -1;
|
|
||||||
for (int i = 0; i < n; i++) {
|
|
||||||
if (arr[i] % 2 == 0) {
|
|
||||||
if (teklen == 0) {
|
|
||||||
teknach = i;
|
|
||||||
}
|
|
||||||
teklen++;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (teklen > maxlen) {
|
|
||||||
maxlen = teklen;
|
|
||||||
maxnach = teknach;
|
|
||||||
}
|
|
||||||
teklen = 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (teklen > maxlen) {
|
|
||||||
maxlen = teklen;
|
|
||||||
maxnach = teknach;
|
|
||||||
}
|
|
||||||
if (maxnach != -1) {
|
|
||||||
for (int i = 0; i < maxlen; i++) {
|
|
||||||
deletElement(maxnach);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
} while (item != 0);
|
|
||||||
}
|
}
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
y += 50;
|
||||||
|
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)
|
||||||
|
{
|
||||||
|
switch (message)
|
||||||
|
{
|
||||||
|
case WM_COMMAND:
|
||||||
|
{
|
||||||
|
int wmId = LOWORD(wParam);
|
||||||
|
// Разобрать выбор в меню:
|
||||||
|
switch (wmId)
|
||||||
|
{
|
||||||
|
case IDM_ABOUT:
|
||||||
|
DialogBox(hInst, MAKEINTRESOURCE(IDD_ABOUTBOX), hWnd, About);
|
||||||
|
break;
|
||||||
|
case IDM_EXIT:
|
||||||
|
DestroyWindow(hWnd);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case WM_PAINT:
|
||||||
|
{
|
||||||
|
PAINTSTRUCT ps;
|
||||||
|
HDC hdc = BeginPaint(hWnd, &ps);
|
||||||
|
// TODO: Добавьте сюда любой код прорисовки, использующий HDC...
|
||||||
|
switch (mode) {
|
||||||
|
case image0:
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
EndPaint(hWnd, &ps);
|
||||||
|
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case WM_KEYDOWN:
|
||||||
|
mode = (enum Modes)(mode + 1); // переключение на следующий режим
|
||||||
|
if (mode == mode_none) mode = image0; // если режимы закончились - начинаем заново
|
||||||
|
InvalidateRect(hWnd, NULL, TRUE);
|
||||||
|
break;
|
||||||
|
case WM_DESTROY:
|
||||||
|
PostQuitMessage(0);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
return DefWindowProc(hWnd, message, wParam, lParam);
|
||||||
|
}
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
return (INT_PTR)FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user