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

На шахматной доске отметить все клетки, которые бьет слон

08.02.2015, 12:03. Показов 7326. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Шахматная доска – игровое поле 8 × 8. Сформировать двумерный
массив A[8][8] – схематическое изображение доски, на котором отметить
положение слона на доске и все клетки, которые бьет слон. Координаты
слона на шахматной доске вводятся с клавиатуры в шахматной нотации, то
есть в виде “e4”, где сначала записывается номер столбца (буква от “a” до
“h”, слева направо), затем номер строки (цифра от 1 до 8, снизу вверх).
Клетку, где стоит слон, отмечают буквой “С”, клетки, которые бьет слон,
отметьте символами “*”, остальные клетки заполните точками.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
08.02.2015, 12:03
Ответы с готовыми решениями:

На шахматной доске стоят черный король и белые ладья и слон (ладья бьет по горизонтали и вертикали, слон – по
Помогите решить проблему error C2668: fabs: неоднозначный вызов перегруженной функции На шахматной доске стоят черный король и белые...

Найти возможные пути для шахматной фигуры «слон» от одной клетки до другой
Найти возможные пути для шахматной фигуры «слон» от одной клетки до другой в пределах шахматной доски. Определить кратчайшие.

Одного ли цвета клетки на шахматной доске?
Даны координаты двух полей шахматной доски (координаты клетки - это 2 числа от 1 до 8: номер столбца и номер строки) Одно ли цвета эти...

15
2 / 2 / 1
Регистрация: 03.02.2015
Сообщений: 23
08.02.2015, 12:08
И в чем вопрос?
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 12:28
C++
1
2
3
4
5
6
7
8
9
char *S = "e4";
n = S[0] - 'a';
m = S[1] - 1;
for(i=0; i<8; i++)
for(j=0; j<8; j++) {
  if (i==n && j==m) A[i][j] = 'C';
  else if (abs(i-n) == abs(j-m)) A[i][j] = '*';
  else A[i][j] = '.';
}
0
2 / 2 / 1
Регистрация: 03.02.2015
Сообщений: 23
08.02.2015, 12:53
Не понимаю, почему все стараются быстренько выпендрится и написать прогу за нерадивого студента?

А они только пользуются этим и засирают форум шлаком. Лучше бы мозги включили
1
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 12:55
Цитата Сообщение от magnetall Посмотреть сообщение
Не понимаю, почему все стараются быстренько выпендрится и написать прогу за нерадивого студента?
Каждый развлекается, как может. Вы вот любите ругаться. А я шахматы люблю.
0
2 / 2 / 1
Регистрация: 03.02.2015
Сообщений: 23
08.02.2015, 12:59


Дело не в ругаться. Просто, если все за них делать, они думать перестают. Еще и подкрепляют это тем, что если в просьбе о помощи есть какой то код - называют "говнокодом" (каким он и является, не спорю) и не помогают
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 13:05
Ведь вы совсем недавно в этом монастыре? Так зачем свой устав предлагать?
Цитата Сообщение от magnetall Посмотреть сообщение
Не понимаю,
А вы мозги включить не пробовали?
Цитата Сообщение от magnetall Посмотреть сообщение
А они только пользуются этим
Как я понял, ваша филиппика направлена не столько на нерадивых студентов, как на тех, кто им помогает. На меня, в частности.

Добавлено через 2 минуты
magnetall, Ладно, ссорится не будем. Я горяч, есть грех, но отходчив... Понимаю, вы никого обидеть не хотели. Но так получилось...
0
2 / 2 / 1
Регистрация: 03.02.2015
Сообщений: 23
08.02.2015, 13:12
Цитата Сообщение от Байт Посмотреть сообщение
Как я понял, ваша филиппика направлена не столько на нерадивых студентов, как на тех, кто им помогает. На меня, в частности.
Я бы сказал на обе стороны.

Цитата Сообщение от Байт Посмотреть сообщение
Ладно, ссорится не будем.
Я и не собирался... да и не лично вам это писалось. Так, мысли в слух

Добавлено через 3 минуты
Цитата Сообщение от Байт Посмотреть сообщение
Ведь вы совсем недавно в этом монастыре? Так зачем свой устав предлагать?
Извеняюсь, перепутал. На других похожих форумах видел темы типа "Новичкам: Насчет халявы", казалось и здесь было
0
08.02.2015, 13:21

Не по теме:

Кто-то добрый "помог" умственно отсталому солдату попасть в армию, получить автомат, а в результе 6 трупов. Может, это был врач из комиссии или военком, которым тоже "помогли" закончить медвуз, академию...

0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 13:40
zer0mail, с вашим доводом нельзя не согласиться. Но что касается меня, я, как правило, стараюсь помочь, научить. С клиническими случаями стараюсь не связываться.
Удается ли это мне - другой вопрос
0
4949 / 2289 / 287
Регистрация: 01.03.2013
Сообщений: 5,991
Записей в блоге: 32
08.02.2015, 16:52
magnetall, меня сначала тоже это удивляло. А потом понял, что этот монастырь живет за счет рекламы, поэтому нужна массовость, поэтому модераторы потокают халявщикам. Помню, в одном клиническом случае на требование написать программу решения нелинейного уравнения, ответил котом рекурсивного обхода графа с граничными условиями и в конце просто печатающим корень уравнения в лоб числом - даже спасибо за это заработал Развлекайтесь творчески! Хотите, можем написать задачу стартового поста не в консоли а на WinApi GDI или вообще на опЕнгле с анимацией движений слона
1
2 / 2 / 1
Регистрация: 03.02.2015
Сообщений: 23
08.02.2015, 17:07
_Ivana, спасибо за пояснение.
0
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
08.02.2015, 18:07
Цитата Сообщение от _Ivana Посмотреть сообщение
можем написать задачу стартового поста не в консоли
угу
Байт, спёр твой код, а он с ошибками я неудачник
говнокод:
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
#include <SFML/Graphics.hpp>
 
 
 
int main()
{
   char A[8][8] = {0} ;
   char * S = "e4";
   int n = S[0] - 'a';
   int m = S[1] - '0' ;
   for(int i=0; i<8; i++)
   {
      for(int j=0; j<8; j++)
      {
         if (abs(i-n) == abs(j-m)) A[i][j] = '*';
         else A[i][j] = '.';
      }
   }
   A[m][n] = 'C' ;
 
   sf::RenderWindow app(sf::VideoMode(800, 600), "SFML window");
   sf::Texture texture;
   sf::RectangleShape whiteBox ;
   sf::RectangleShape blackBox ;
   sf::CircleShape selectCircle ;
   if (!texture.loadFromFile("слон.png"))
      return EXIT_FAILURE;
   sf::Sprite sprite(texture);
   sf::Rect<float> spriteRect = sprite.getLocalBounds() ;
   selectCircle.setRadius(spriteRect.width/2.0f) ;
   selectCircle.setFillColor( sf::Color(255,0,0,50) ) ;
   whiteBox.setSize( sf::Vector2f(spriteRect.width,spriteRect.height) ) ;
   whiteBox.setFillColor(sf::Color::White) ;
   blackBox.setSize(whiteBox.getSize()) ;
   blackBox.setFillColor(sf::Color(127,127,127,255)) ;
 
   while (app.isOpen())
   {
      sf::Event event;
      while (app.pollEvent(event))
      {
         if (event.type == sf::Event::Closed)
            app.close();
      }
      app.clear(sf::Color::White);
      for(int i=0; i<8; i++)
      {
         for(int j=0; j<8; j++)
         {
            if ( i%2 + j%2 == 1 )
            {
               blackBox.setPosition(j*spriteRect.width,i*spriteRect.height) ;
               app.draw(blackBox) ;
            } else
            {
               whiteBox.setPosition(j*spriteRect.width,i*spriteRect.height) ;
               app.draw(whiteBox) ;
            }
         }
      }
      for(int i=0; i<8; i++)
      {
         for(int j=0; j<8; j++)
         {
            switch ( A[i][j] )
            {
            case 'C' :
               sprite.setPosition(j*spriteRect.width,i*spriteRect.height) ;
               app.draw(sprite) ;
               break ;
            case '*' :
               selectCircle.setPosition(j*spriteRect.width,i*spriteRect.height) ;
               app.draw(selectCircle) ;
               break ;
            default:
               break ;
            }
         }
      }
      app.display();
   }
   return EXIT_SUCCESS;
}
Кликните здесь для просмотра всего текста
3
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 18:21
Цитата Сообщение от Croessmah Посмотреть сообщение
Байт, спёр твой код, а он с ошибками
Угу! Надо
C++
1
m = S[1] - '1';
Но как у тебя правильно получилось с
C++
1
m = S[1] - '0';
Или это накладка?
А, понял. Для поля "e8" у тебя слон соскочит с доски...Или я чего недопонимаю???
1
Неэпический
 Аватар для Croessmah
18149 / 10731 / 2067
Регистрация: 27.09.2012
Сообщений: 27,035
Записей в блоге: 1
08.02.2015, 18:24
Цитата Сообщение от Байт Посмотреть сообщение
А, понял. Для поля "e8" у тебя слон соскочит с доски...Или я чего недопонимаю???
Всё правильно. Я же даже клетки не правильно расставил. Это просто рисование сугубо в этой позиции. Если нужно, напишу правильно
0
Диссидент
Эксперт C
 Аватар для Байт
27714 / 17332 / 3810
Регистрация: 24.12.2010
Сообщений: 38,978
08.02.2015, 18:32
Цитата Сообщение от Croessmah Посмотреть сообщение
Если нужно, напишу правильно
Мне не нужно...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
08.02.2015, 18:32
Помогаю со студенческими работами здесь

Верно ли высказывание, что слон, расположенный на поле (x1, y1) шахматной доски, «бьет» поле (x2, y2)
Верно ли высказывание, что слон, расположенный на поле (x, y) шахматной доски, «бьет» поле (x1, y1) (x1, y1, x, y – целые от1 до 8); ...

Определить, являются ли клетки (a, b), (c, d) полями одного цвета на шахматной доске
Поле шахматной доски имеет размер 8 х 8. Клетки определяются координатами, первая из которых - номер вертикали (слева направо), вторая -...

Одного ли цвета эти клетки на шахматной доске?
Как решить задачу - Даны координаты двух полей шахматной доски. Координаты клетки - это два числа от 1 до 8: номер столбца и номер строки....

Отметить клетки, которые оказываются под ударом ладьи
Есть позиция ладьи, нужно отметить клетки, которые оказываются под ударом. #include &lt;iostream&gt; #include &lt;time.h&gt; ...

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


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

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица. Задача: зафиксировать три левых колонки в отчете. Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка) / / . . .
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru