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

Сдвиг столбцов влево циклически - матрица - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ как правильно юзать str() http://www.cyberforum.ru/cpp-beginners/thread568361.html
// stringstream::str #include <iostream> #include <sstream> #include <string> using namespace std; int main () { stringstream oss; string mystr;
C++ Не могу перевести их pascal Добрый день. написал программу на паскале var x:array of integer; a,s,d,f,n,i,j,k:integer; rt,rt2,h,c:integer; begin writeln('введите n'); readln(n); http://www.cyberforum.ru/cpp-beginners/thread568349.html
Массив объектов C++
Задумка: Сделать некую подобию базы данных, список из "объектов". К объектам привязаны соответствующие данные разных типов (int, char и тд). С этими данными мне нужно будет в дальнейшем работать, поэтому должен быть постоянный доступ ко всем объектам в списке. К примеру, ОБЪЕКТ: Федя - 21 (год) - 72(вес). Изначально список пуст. Программа должна включать в себя возможность добавления вручную...
C++ Пузырьковая сортировка
Написал программу сортировки методом пузырька: #include <stdio.h> #include <conio.h> #include <cstdlib> int main(){
C++ Заполнение массива http://www.cyberforum.ru/cpp-beginners/thread568335.html
Заполнить массив двадцатью первыми натуральными числами, делящимися нацело на 13 или на 17 и находящимися в интервале, левая граница которого равна 300. #include <iostream> using namespace std; int main () { int array1 ; int d = 300;
C++ вещественная матрица ]помогите пожалуйста напечатать заданную вещественную матрицу , расположив ее столбцы в порядке невозрастания их l1 норм (||x||=||x1||+...||xn||). Использовать метод выборки минимальных элементов. делаю вот так а дальше что-то не получается: #include "stdafx.h" #include<iostream> #include<cmath> using namespace std; int _tmain(int argc, _TCHAR* argv) {int c,b,t,i, nums, a; int size=4; подробнее

Показать сообщение отдельно
Tantay
0 / 0 / 0
Регистрация: 28.04.2012
Сообщений: 110
08.05.2012, 02:29     Сдвиг столбцов влево циклически - матрица
Приветствую. Хотелбы узнать как реализовать такое что бы, найдя максимальный элемент в матрице, сдвинуть столбец с максимальным элементом на место первого столбца, ну и естественно остальные остолбцы сдвинуть циклически влево. Вот мой код но пока успеха мало(((

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
cout << ("Введите колличество строк - n и столбцов - m: \n");
    cout <<("Строки  - ");  cin >> n; 
    cout << ("Столбцы - "); cin >> m; 
    cout << endl;
 
    // объявление двумерного динамического массива
    int **c = new int*[n];    // n строк в массиве
    for (i=0; i<n; i++){
        c[i] = new int [m];  // и m столбцов
    }
    srand ( time(0) );
    for (i=0; i<n; i++){
        for (j=0; j<m; j++)
            c[i][j] = ((rand() %13) -4);
            //mas[i][j] = (((rand() %9) -4)/double((rand() %9) -4));
    }
    for (i=0; i<n; i++){
        for (j=0; j<m; j++){
            cout.width(4); cout.precision(2); 
            cout << c[i][j] << " ";
        }
            cout << endl << endl;
    }
 
//определение строки и столбца с максимальным элементом
    int maxStr = 0, maxStb = 0;
    for (int i = 0; i < n; i++){
        for (int j = 0; j < m; j++){
            if (c[maxStr][maxStb] < c[i][j]){
                maxStr = i;
                maxStb = j;
            }
        }
    }
 
    cout << c[maxStr][maxStb] << endl;
    cout << "MaxStr: " << (maxStr+1) << endl;
    cout << "MaxStb: " << (maxStb+1) << endl;
 
//моя попытка хоть как то реализовать на примере 
//простого сдвига столбцов вправо, но без результатно(
 
/*  for (i=0;i<n;i++){
        rab=c[i][maxStb];
        for (j=0;j<m;j++){
            if (c[i][maxStb]!=c[i][0])
                c[i][maxStb]=c[i][maxStb+1];
            while (c[i][maxStb-1] != c[i][2]){
                k=i-1;
                c[i][k]=c[i][j];}
        }
        c[i][0]=rab;
    }
*/
 
//а вот пример простого сдвига столбцов в право
/*  for (i=0;i<=4;i++){
              rab=a[i][5];
              for (j=4;j>=0;j--){
                k=j+1;
                a[i][k]=a[i][j];
              }
              a[i][0]=rab;
      }*/
 
 
//вывод матрицы после преобразований
    for (int i=0; i<n; i++){
        for (int j=0; j<m; j++){
            cout.width(4); cout.precision(2);
            cout << c[i][j] << "   ";
        }
        cout << endl << endl;
    }
 
// высвобождение памяти отводимой под двумерный динамический массив:
    for (int i=0; i<n; i++) 
        delete [] c[i];
    system ("pause");
}
прошу прощения за громоздкость)))
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 02:34. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru