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

Задача на заполнение матрицы(С++) - C++

Восстановить пароль Регистрация
 
neprog
0 / 0 / 0
Регистрация: 03.05.2012
Сообщений: 5
03.05.2012, 15:51     Задача на заполнение матрицы(С++) #1
Доброго времени суток
Может ли мне кто-нибудь помочь решить задачу:

Прямоугольную матрицу размерами не более, чем 20х20 (вводятся с клавиатуры) заполнить следующим образом: с клавиатуры вводятся координаты клетки, в которую нужно записать 1, в окаймляющие ее клетки (8 соседних) – 2, элементам следующего окаймления присвоить 3 и т.д. Причем первая клетка может находиться и за пределами матрицы (иметь положительные и отрицательные координаты в пределах –20…40.

Заранее спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
03.05.2012, 15:51     Задача на заполнение матрицы(С++)
Посмотрите здесь:

Заполнение матрицы C++
Заполнение матрицы C++
Заполнение матрицы C++
Заполнение матрицы! C++
Заполнение матрицы C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
valeriikozlov
Эксперт C++
 Аватар для valeriikozlov
4660 / 2486 / 321
Регистрация: 18.08.2009
Сообщений: 4,550
03.05.2012, 21:15     Задача на заполнение матрицы(С++) #2
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
#include<iostream>
using namespace std;
 
int main()
{
    int a[61][61]={0}, i, j, I, J, N, M, time=1;
    bool fl=true;
    cout<<"N= "; cin>>N;
    cout<<"M= "; cin>>M;
    cout<<"I_start= "; cin>>I;
    cout<<"J_start= "; cin>>J;
    a[I+20][J+20]=1;
    while(fl)
    {
        fl=false;
        for(i=0; i<61; i++)
            for(j=0; j<61; j++)
                if(a[i][j]==time)
                {
                    if(i>0)
                    {
                        if(a[i-1][j]==0)
                        {fl=true; a[i-1][j]=time+1;}
                        if(j>0 && a[i-1][j-1]==0)
                        {fl=true; a[i-1][j-1]=time+1;}
                        if(j<60 && a[i-1][j+1]==0)
                        {fl=true; a[i-1][j+1]=time+1;}
                    }
                    if(i<60)
                    {
                        if(a[i+1][j]==0)
                        {fl=true; a[i+1][j]=time+1;}
                        if(j>0 && a[i+1][j-1]==0)
                        {fl=true; a[i+1][j-1]=time+1;}
                        if(j<60 && a[i+1][j+1]==0)
                        {fl=true; a[i+1][j+1]=time+1;}
                    }
                    if(j>0 && a[i][j-1]==0)
                    {fl=true; a[i][j-1]=time+1;}
                    if(j<60 && a[i][j+1]==0)
                    {fl=true; a[i][j+1]=time+1;}
                }
        time++;
    }
    for(i=0; i<N; i++)
    {
        for(j=0; j<M; j++)
        {
            cout.width(3);
            cout<<a[i+20][j+20];
        }
        cout<<endl;
    }
    return 0;
}
neprog
0 / 0 / 0
Регистрация: 03.05.2012
Сообщений: 5
04.05.2012, 08:52  [ТС]     Задача на заполнение матрицы(С++) #3
Огромное спасибо! valeriikozlov
neprog
0 / 0 / 0
Регистрация: 03.05.2012
Сообщений: 5
15.05.2012, 15:50  [ТС]     Задача на заполнение матрицы(С++) #4
день добрый.
Помогите решить задачку: для массива Х(100) найти наибольший элемент; заменить его значением суммы элементов, предшествующих ему.
Yandex
Объявления
15.05.2012, 15:50     Задача на заполнение матрицы(С++)
Ответ Создать тему
Опции темы

Текущее время: 11:14. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru