Форум программистов, компьютерный форум, киберфорум
Наши страницы

Морской Бой - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Массив http://www.cyberforum.ru/cpp-beginners/thread67891.html
"Дана последовательность из N вещественных чисел. Найти количество чисел, больших последнего числа из последовательности". Нужна прога на С. Выручайте кто-нибудь! :)
C++ Открыть изображение, на котором бы были ссылки (кнопки) для запуска программ. С чего начать? Подскажите пожалуйста! Хочу создать приложение, которое бы открывало изображение, на которм бы были ссылки(кнопки) для запуска программ.С помощью какой программы это лучше сделать? И можно ли создать... http://www.cyberforum.ru/cpp-beginners/thread67861.html
Передача двумерного массива в функцию C++
проблема в том что в функция inicil не изменяет похожу массива, и в output выводятся нелепые числа... #include <iostream> #include <iomanip> #include <time.h> #include <conio.h> using...
C++ Необъявленный идентификатор
И снова ВСЕМ добрый вечер!!!:) Написав десяток примеров из книги, в качестве упражнений для себя и закрепления материала решил на основе полученных мною знаний своять свой пример программки!...
C++ while и последний повтор цикла http://www.cyberforum.ru/cpp-beginners/thread67829.html
Привет всем...дело вот в чём: я пишу блекджек(консольную версию) и в процессе наткнулся на трудность...у пользователя есть выбор взять карту или нет(цифра 1 что бы взять и цифра 2 что бы нет), что бы...
C++ указатели всем здрасте, вот у меня проблема, я категорически не понимаю "указателей" можете как нить обяснить или дать хорошую статью на эту тему, пожалуйста!!! подробнее

Показать сообщение отдельно
Vladimir.
157 / 157 / 10
Регистрация: 24.11.2009
Сообщений: 375
27.11.2009, 16:01
Вчера решал кому-то задачу с матрицами, класс редактировался на скорую руку, так что не обращайте внимания на double, ну или перепишите, если не лениво.
спойлер

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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
#include<iostream>
using namespace std;
class SquareMatrix
{
      private:
             double** matrix;
             int dimm;
             void Create()
             {
                matrix = new double* [dimm];
                for (int i=0; i<dimm; i++)
                    matrix[i]= new double [dimm];            
                
             }
      public:
             SquareMatrix(int n): dimm(n) {Create();}
            ~SquareMatrix()
            {
                   for (int i=0; i<dimm; i++)
                       delete[] matrix[i];
                   delete[] matrix;
            }
            
            double get(int i, int j)
            {   
                if (((i>0)&&(i<dimm)&&(j>0)&&(j<dimm)))return matrix[i][j]; 
                //Если вызываем элемент вне границ матрицы, возвращает ноль.
                else if(i<0) return 0;
                else if(i>=dimm) return 0;
                else if(j<0) return 0;
                else if(j>=dimm) return 0;
            }
 
            void set(int i,int j, double var)
            {
                matrix[i][j] = var;   
            }
             
 
            void show_matrix()
            {     
         
                  for (int i=0;i<dimm;i++)
                  {
                     for (int j=0;j<dimm;j++)
                     {
                        cout.width(4);
                        cout<<matrix[i][j];
                     }
                     cout<<endl;
                  }
                    
            }   
 
};
 
 
int main()
{
    int dimm = 8; 
    SquareMatrix Sea(dimm); 
//Естественно матрицу нужно заполнить.             
//     Sea.set(int i,int j, double set_value);
    
// Дальше логика такая: пробегаем строку слева направо.
// При если обнаружили 1, выполняем проверку.
    int one=0,two=0,three=0,four=0;//счетчики кораблей.
    
    for(int row=0;row<dimm;row++)
    {
        for(int index=0;index<dimm;index++)
        {
            if ( Sea.get(row,index)==1) 
            {
                //Мы встретили корабль, проверим, а не вертикальный ли он.
                if((Sea.get(row-1,index)==1)||(Sea.get(row+1,index)==1)) continue;
                //Не вертикальный. Начинаем считать палубы...
                int counter = 0;
                while((Sea.get(row,index)==1)) {counter++;index++;}
                switch(counter)
                {
                    case 1: one++; break;
                    case 2: two++; break;
                    case 3: three++; break;
                    case 4: four++; break;
                    default: cout<<"Error: 1;"<<endl;
                }
            }
        }
        //конец строки.
    }
    // Абсолютно то же самое для столбцов:
    for(int col=0;col<dimm;col++)
    {
        for(int index=0;index<dimm;index++)
        {
            if ( Sea.get(index,col)==1) 
            {
                if((Sea.get(index,col-1)==1)||(Sea.get(index,col+1)==1)) continue;
                int counter = 0;
                while((Sea.get(index,col)==1)) {counter++;index++;}
                switch(counter)
                {
                    case 1: one++; break;
                    case 2: two++; break;
                    case 3: three++; break;
                    case 4: four++; break;
                    default: cout<<"Error: 1;"<<endl;
                }
            }
        }
    }    
    
    // однопалубные посчитаны дважды:
    if (one%2) cout<<"Error: 2;"<<endl;
       else one /=2; 
    // Всё, задача решена, осталось только вывести результат..... 
        
        
    
    return 0;
}
0
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru