Форум программистов, компьютерный форум CyberForum.ru

Матрицы. Удаление строк. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ В таблице из N строк и N столбцов клетки заполнены цифрами от 0 до 9. Требуется найти такой путь из клетки (1, 1) в клетку (N, N http://www.cyberforum.ru/cpp-beginners/thread571715.html
В таблице из N строк и N столбцов клетки заполнены цифрами от 0 до 9. Требуется найти такой путь из клетки (1, 1) в клетку (N, N), чтобы сумма цифр в клетках, через которые он пролегает, была минимальной; из любой клетки ходить можно только вниз или вправо. Ограничения: 2 <= N <= 250. Ввод: В первой строке находится число N. В следующих N строках содержатся по N цифр без пробелов. Вывод:...
C++ Разработать иерархию классов Подъемный кран. Необходимо разработать иерархию классов.В каждом классе иерархии нужно предусмотреть: 1)Наличие не менее 3х конструкторов 2)Виртуальный деструктор 3)Перезагрузка операции. Обязательно перезагрузить операции: присвоение, инкременты и дискремента в обеих формах, поместить в поток , взять из потока, любую из бинарных и любую из унарных операций. 4)Виртуальная функция ... http://www.cyberforum.ru/cpp-beginners/thread571700.html
C++ Error C2109: для индекса требуется массив или указатель
#include <stdio.h> #include <conio.h> int const max_widht=3; int const max_height=3; int minmax (int min, int max, int val, int max_height, int max_widht, int* m) { int i,max_w, min_w; for (int i=0; i<max_widht; i++) {
C++ Запуск Gnu через командную строку
Здравствуйте, у меня возникла проблема такая интересная (лично для меня :D), вобщем до недавнего времени я занимался паскалем и решил перейти на С++, учебник который я скачал для новичков т.е. изучать С++ не зная С, и вобщем там используется Gnu а вот как его запускать через командную строку я незнаю xD помогите пожалуйста ламеру =)
C++ Циклическая форма реккурентного соотношения. http://www.cyberforum.ru/cpp-beginners/thread571670.html
Добрый день. Есть задание: "Реализовать функции, считающие n-ый элемент рекуррентного соотношения в рекуррентной и циклической формах. Т(n)=7T(n/3)+n^2" В реккурентной форме реализовал, а как с циклической быть не понимаю :( Подскажите пожалуйста в какую сторону копать?
Visual C++ Пауза в однопоточном приложении MFC Создаю приложение, в котором показывается пошаговая работа алгоритма. И необходимо, чтобы между некоторыми операциями была пауза в несколько секунд. Пытался использовать: if (autoBTN) { Sleep (stepTime); } Такие паузы нужны в нескольких местах выполнения одной функции. Разбить её на несколько - не вариант Но пока идёт Sleep, окно не обрабатывает сообщения и система считает, что оно... подробнее

Показать сообщение отдельно
ArmoredHell
 Аватар для ArmoredHell
15 / 15 / 1
Регистрация: 05.04.2012
Сообщений: 32
19.05.2012, 23:59     Матрицы. Удаление строк.
C
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
#include<stdio.h>
#include<stdlib.h>
 
void print(int M, int N, double** mas)
{
    if( M == 0 ) { printf("Matritsa pystaia\n"); return; }
    printf("Razmer matrisi : %d x %d\n", M, N);
 
    printf("Novaia matritsa :\n");
    for(int i = 0; i < M; i++) 
    {
        for(int j = 0; j < N; j++) 
            printf("%lf ", mas[i][j]);
 
        printf("\n");
    }
}
 
 
void newRemoveRows(double** mas, int M, int N, int K1, int K2)
{
    if( K1 > M ) return;
    if( K2 > M ) 
    {
        for(int i = (K1 - 1); i < M; i++)
        {
            free(mas[i]);
        }
        M = K1 - 1;
        print(M, N, mas);
        return;
    }
 
    for(int i = (K1 - 1); i <= (K2 - 1); i++)
    { 
        free(mas[i]);
    }
 
 
    int delete_size = K2 - K1 + 1;
    int new_razm = M - delete_size;
 
    int pos = K1 - 1;
    for(int i = K2; i < M; i++) { mas[pos] = mas[i]; pos++; }
    
    print(new_razm, N, mas);
}
 
int main()
{
    int M = 0, N = 0, K1 = 0, K2 = 0;
 
    printf("Vvedite razmer matrici : ");
    scanf("%d%d",&M, &N);
    printf("Vvedite ydaliaemie stroki [K1, K2] : ");
    scanf("%d%d",&K1, &K2);
 
    double** mas = (double**)malloc(sizeof(double)*(M));
 
    for(int i = 0; i < M; i++)
        mas[i] = (double*)malloc(sizeof(double)*(N));
 
    printf("Vvedite matricy:\n");
    for(int i = 0; i < M; i++)
    {
        printf("Vvedite %d stroky matrici :", i+1);
        for(int j = 0; j < N; j++)
        {
            scanf("%lf", &mas[i][j]);
        }
    }
    printf("\n");
 
    newRemoveRows(mas, M, N, K1, K2);
 
    system("PAUSE");
    return 0;
}
 
Текущее время: 06:32. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru