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

Осуществить циклический сдвиг элементов квадратной матрицы - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Вывод на экран чисел из файла http://www.cyberforum.ru/cpp-beginners/thread260730.html
нужно считать числа из файла, записать в массив и вывести на экран. подскажите, в чём ошибка? int main(int argc, char* argv) { ifstream file; file.open(filename); int a=0,g=0,i=0; //считаем кол-во элементов while(!file.eof()) {
C++ Вычислить значение выражения здравствуйте, не могу разобраться(((( http://www.cyberforum.ru/cpp-beginners/thread260729.html
C++ Найти самое длинное слово в сообщении (строки)
что-то туплю, задача то не сложная.... #include <iostream> #include <string> using namespace std; int main() { string str,slovo,simvol; string::size_type k=0, pos=0; cout<<"vvedi stroku"<<endl;
Составить программу, используя классы стандартной библиотеки шаблонов C++
Буду благодарен если поможете. Спасибо. Составить программу, используя последовательные классы стандартной библиотеки шаблонов С++, которая содержит текущую информацию о книгах в библиотеке. Сведения о книгах содержат: • номер УДК; • фамилию и инициалы автора; • название; • год издания; • количество экземпляров данной книги в библиотеке. Программа должна обеспечивать:
C++ Напечатать сначала все отрицательные числа этой последовательности, затем все положительные http://www.cyberforum.ru/cpp-beginners/thread260712.html
Дана последовательность ненулевых целых чисел, за которой следует 0. Напечатать сначала все отрицательные числа этой пос¬ледовательности, за-тем - все положительные (в любом порядке). Помогите пожалуйста)
C++ Слияние массивов я новичек в программировании. Помогите пожалуйста решить слудеющию задачу на С++. Заданы три упорядоченных по возрастанию массива f, g, h Составить программу слияния этих массивов. Если возможно, привидите пожалуйста листинг. Заранее благодарю тех, кто откликнулся. подробнее

Показать сообщение отдельно
IrineK
Заблокирован
20.03.2011, 22:19     Осуществить циклический сдвиг элементов квадратной матрицы
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
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <conio.h>
#define N 6
 
int main()
{       int spiral[N][N], Step, cur[4*(N-1)], shift[4*(N-1)];
        int i,j,k,c,edge;
 
//инициализация массива числами от 1 до 20
        srand(time(NULL));
        printf("Original array:\n");
        for(i=0;i<N;i++)
        {       for(j=0;j<N;j++) 
                {   spiral[i][j]=rand()%20+1;
                    printf("%6d",spiral[i][j]);
                }
                printf("\n");
        }
//запрос количества шагов поворота
        printf("\nHow many steps to turn? Step = ");
        scanf("%d",&Step);
        
        for(k=0; k<N/2;k++) //слои
        {       edge = N-1-k;
                
//снять слой      
        c=0;
        for(j=k;j<edge;j++)             
                {      cur[c] = spiral[k][j];
                        c++;
                }
                for(i=k;i<edge;i++)             
                {      cur[c] = spiral[i][edge];
                        c++;
                }
                for(j=edge;j>=k;j--)    
                {      cur[c] = spiral[edge][j];
                        c++;
                }
                for(i=edge-1;i>k;i--)             
                {       cur[c] = spiral[i][k];
                        c++;
                }
//переставить
        for(i=0;i<4*(N-2*k-1);i++)
            shift[(i+Step)%(4*(N-2*k-1))]=cur[i];
 
//одеть слой        
        c=0;
        for(j=k;j<edge;j++)             
                {   spiral[k][j] = shift[c];   
                    c++;
                }
                for(i=k;i<edge;i++)             
                {    spiral[i][edge]= shift[c];
                        c++;
                }
                for(j=edge;j>=k;j--)    
                {    spiral[edge][j]= shift[c];
                        c++;
                }
                for(i=edge-1;i>k;i--)             
                {     spiral[i][k]= shift[c];
                        c++;
                }
        }//for - переход на следующий слой
      
 //Результат
        printf("Result:\n");
        for(i=0;i<N;i++)
        {       for(j=0;j<N;j++) printf("%6d",spiral[i][j]);
                printf("\n");
        }
 
        getch();
        return 0;
}

Добавлено через 9 минут. ну как там?
Мда-с. Весело. :dance3:
 
Текущее время: 15:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru