Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
1 / 1 / 0
Регистрация: 13.12.2011
Сообщений: 10

"Разбить" программу на несколько функций

23.12.2011, 21:06. Показов 813. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть готовая программа по матрицам, нужно "разбить" её на несколько функций (нахождение столбцов с равными элементами и их удаление и подсчет суммы строк и вывод сумм строк с номерами равными координатам вектора)

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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#include <stdio.h>
#include <conio.h>
 
void main(void)
{
    int a[100][100],m,n,i,j,k,b[100][100],l,p=0, q, g[100],c;
 
 
    puts("vvedite kolichestvo strok m\n");
    scanf("%d",&m);
    puts("vvedite kolichestvo stolbcov n\n");
    scanf("%d",&n);
            puts("\nvvedite matricy");
    for (int i=0; i<m; i++)
     for (int j=0; j<n; j++)
       {
        printf ("a[%d][%d]= ", i+1,j+1);
        scanf ("%d", &a[i][j]);
       }
    puts("\nvi vveli matricu B\n");
    for(i=0;i<m;i++)
    {
        for(j=0;j<n;j++)
            printf("%6d",a[i][j]);
        puts("\n");
    }
 
 
    for(j=0;j<n;j++)                      //нахождение столбцов с равными элементами и их удаление 
    {
        for(l=0,i=0;i<m;i++)
        {
            for(k=0;k<m;k++)
            {
                if(a[i][j]==a[k][j])
                            l++;
 
            }
 
        }
                if(l==k)
        {
            for(l=0;l<n;l++)
                b[l][p]=a[l][j];
            p++;
        }
 
    }
 
 
    puts("\nnovaya matrica C\n");
    for(i=0;i<m;i++)
    {
        for(j=0;j<p;j++)
            printf("%6d",b[i][j]);
        puts("\n");
    }
 
   printf ("\nvvedite razmer vektora q: ");
    scanf ("%d", &q);
    for (int i=0; i<q; i++)
    {
      printf ("\nvvedite %d koord vektora ", i+1);
      scanf ("%d", &g[i]);
    }
     printf ("\nvash vektor:\t");
      for (int i=0; i<q; i++)
      {
      printf ("%d\t", g[i]);
      }
 
       for (int i=0; i<q; i++)
        {
        if (g[i]<=0)
         {
          g[i]=g[i+1];
         }
        }
 
 
    float sum;                              // подсчет и вывод сумм строк с номерами равными коорд. вектора
     for (int i=0; i<m; i++)
     {
        sum=0;
        c=0;
          for (int j=0; j<p; j++)
          {
          sum += b[i][j];
          c=i;
          }
        for (int i=0; i<q; i++)
        {
          if (g[i]==c+1)
          {
          printf ("\nsumma %d ctroki = %f\n",c+1, sum)   ;
          }
        }
     }
 
 
   getch ();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
23.12.2011, 21:06
Ответы с готовыми решениями:

Разбить программу на несколько функций
Как сделать эту программу в виде функций, сейчас она работает правильно. Программа ищет все...

Динамический массив, разбить программу на несколько функций
Разбить программу на несколько функций #include&lt;stdio.h&gt; #include&lt;conio.h&gt; #include&lt;locale.h&gt;...

Разбить на несколько функций
Доброго времени суток, подскажите пожалуйста, нужно разбить одну большую функцию, на несколько....

1
49 / 49 / 13
Регистрация: 29.06.2011
Сообщений: 174
24.12.2011, 00:57
Вот пример функции(код не отлажен да и я просто тут закопипастил):
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
int find_stolb(int *a, int *b)
{ 
    int i,j,k,p;
    for(j=0;j<n;j++)                      //нахождение столбцов с равными элементами и их удаление 
        {
                for(l=0,i=0;i<m;i++)
                {
                        for(k=0;k<m;k++)
                        {
                                if(*a[i][j]==*a[k][j])
                                l++;
 
                        }
 
                }
                if(l==k)
                {
                        for(l=0;l<n;l++)
                                *b[l][p]=*a[l][j];
                        p++;
                }
 
         puts("\nnovaya matrica C\n");
        for(i=0;i<m;i++)
        {
                for(j=0;j<p;j++)
                        printf("%6d",*b[i][j]);
                puts("\n");
        }
        return *b;
}
Суть в том, что нужно описать алгоритм, а при вызове функции просто указать аргументы(кажется я кэп)
Для улучшенного понимания советую почитать книгу Кернигана и Ритчи "Программирование на Си" (второе издание)
Конечно лучше использовать указатели(как в данном примере-a и b-указатели на массивы)-сэкономите уйму памяти(если будете работать с БОЛЬШИМ числом элементов)-да и алгоритм можно поэффективней найти
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
24.12.2011, 00:57
Помогаю со студенческими работами здесь

Thread разбить программу в несколько потоков
Всем привет! Народ, такая проблема, написала программу, теперь нужно её разбить на несколько...

Разбить одну программу на несколько параллельно работающих
Я не программист, языка С++ не знаю. Написал ТЗ, по которому программисты что-то сваяли, недоваяли...

Программу с классами разбить на несколько файлов
Здравствуйте. Я учусь программировать на с++ и столкнулся с проблемой. Не могу найти как...

Разбить программу на заданный интервал на несколько диапазонов и проводящую поиск в каждом диапазоне в отдельном процесс
Нужно написать программу, разбивающую заданный интервал на несколько диапазонов и проводящую поиск...

Разбить строку на несколько частей?
Здравствуйте. У меня проблема. Я только начинаюший в Builder-e и вообще любитель чё-нибудь...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
BOINC: 22 года — и всё ещё работает
Programma_Boinc 12.03.2026
BOINC: 22 года — и всё ещё работает Дэвид Андерсон написал ретроспективу. Кратко: в 2001 году он ушёл из United Devices, где был CTO, и за несколько месяцев написал ядро BOINC — клиент, сервер,. . .
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru