Queen.cpp 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. #include "Queen.h"
  2. #include "Position.h"
  3. #include <utility>
  4. #include <stdexcept>
  5. #include <iostream>
  6. Queen::Queen(Position pos, char c) {
  7. if (c != 'B' and c != 'W')
  8. throw std::invalid_argument("Impossible color of figure!");
  9. position = pos;
  10. color = c;
  11. }
  12. vector<Position> Queen::get_moves()
  13. {
  14. vector<Position> moves;
  15. // Сначала ходы по диагоналям
  16. for(int i = 1; i < 8; i++) {
  17. for(int j = -1; j < 2; j+=2) {
  18. for(int k = -1; k < 2; k+=2) {
  19. // Не добавляем невозможные ходы
  20. if (not (position.posSym + i*j <= 'H' and position.posNum + i*k <= '8' and position.posSym + i*j >= 'A' and position.posNum + i*k >= '1'))
  21. continue;
  22. // Position создаст ошибку, если создать невозможный ход
  23. Position p;
  24. try {
  25. p = Position((char)(position.posSym+i*j), (char)(position.posNum+i*k));
  26. }
  27. catch (const std::invalid_argument) {
  28. p = Position();
  29. }
  30. moves.push_back(p);
  31. }
  32. }
  33. }
  34. // По прямым
  35. for (int i = 1; i < 9; i++) {
  36. Position p;
  37. Position p2;
  38. // Position создаст ошибку, если создать невозможный ход
  39. try {
  40. if ('0'+i != position.posNum) p2 = Position(position.posSym, (char)('0'+i));
  41. if ('0'+i+16 != position.posSym) p = Position((char)('0'+i+16), position.posNum);
  42. }
  43. catch (const std::invalid_argument) {
  44. continue;
  45. }
  46. if ('0'+i+16 != position.posSym) {
  47. moves.push_back(p);
  48. }
  49. if ('0'+i != position.posNum) {
  50. moves.push_back(p2);
  51. }
  52. }
  53. return moves;
  54. }
  55. const char* Queen::print()
  56. {
  57. const char* me;
  58. if (color == 'B')
  59. me = "♛";
  60. else
  61. me = "♕";
  62. return me;
  63. }