一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
码农求职神器Triplebyte:
不用海投,内推你去多家公司面试
Airbnb 数据科学职位
in analytics and inference
天天打游戏、照样领工资,
你要不要来?
把贵司招聘信息放这里
查看: 168|回复: 2
收起左侧

akuna俄罗斯方块code

[复制链接] |试试Instant~ |关注本帖
leonard_lin 发表于 2017-12-3 03:48:45 | 显示全部楼层 |阅读模式

2017(10-12月) 码农类 硕士 全职@akuna - 网上海投 - 在线笔试 |Other其他

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?Sign Up 注册获取更多干货

x
我不找工作,但看到大家遇到的akuna俄罗斯方块题目,就用c++做了一下,仅供参考,有问题随时反映,以及说明两点.1point3acres缃
1. 题目好像没有说w和h代表什么,我当w代表横的,h代表竖的
2. 题目好像也没有说什么是更靠近左下角,比如(0,1)和(1,0)哪个更靠近左下角呢?我当总是从横坐标小的开始
. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
class Solution {
public:
int helper(vector<vector<bool>>& grid, int w, int h, vector<vector<pair<int, int>>>& pieces, int st, int row, int lastX, int lastY) {.鏈枃鍘熷垱鑷1point3acres璁哄潧
  if (st == row) {
   for (int i = 1; i < h - 1; ++i) {
    for (int j = 1; j < w - 1; ++j) {
     if (!grid[i][j]) {
      return -1;
     }
    }
   }
   return lastX * lastY;
  }
  int len = pieces[st].size();
  for (int i = 1; i < h - 1; ++i) {
   for (int j = 1; j < w - 1; ++j) {
    if (!grid[i][j] && grid[i - 1][j] && grid[i][j - 1] && grid[i][j + 1] && grid[i + 1][j]) {
     return -1;
    }.鏈枃鍘熷垱鑷1point3acres璁哄潧
   }
  }.鐣欏璁哄潧-涓浜-涓夊垎鍦
  int num = h - 1;. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
  int ind = 1;
  bool indplus = false;
  while (1) {
   if (ind == w - 1) {
    break;
   }
   if (num < 2) {. visit 1point3acres.com for more.
    num = 3;
    ++ind;
    indplus = true;
   }
   for (int j = ind, i = num - j; j < w - 1 && i < h - 1; ++j, ++i) {
    bool out = false;
    for (int k = 0; k < 4; ++k) {.1point3acres缃
     int r = i - pieces[st][k].second;
     int c = j + pieces[st][k].first;
     if (r < 1 || r >= h - 1 ||
      c < 1 || c >= w - 1 ||
      grid[r][c]) {
      out = true;. 鐗涗汉浜戦泦,涓浜╀笁鍒嗗湴
      break;
     }
    }
    if (out) {.鐣欏璁哄潧-涓浜-涓夊垎鍦
     continue;
    }. 涓浜-涓夊垎-鍦帮紝鐙鍙戝竷
    for (int k = 0; k < 4; ++k) {
     grid[i - pieces[st][k].second][j + pieces[st][k].first] = true;
    }. From 1point 3acres bbs
    lastX = h - 3 - (i - pieces[st][0].second - 1);
    lastY = j + pieces[st][0].first - 1;
    int res = helper(grid, w, h, pieces, st + 1, row, lastX, lastY);
    if (res != -1) {
     return res;
    }
    for (int k = 0; k < 4; ++k) {
     grid[i - pieces[st][k].second][j + pieces[st][k].first] = false;
    }
   }.鏈枃鍘熷垱鑷1point3acres璁哄潧
   if (!indplus) {.鐣欏璁哄潧-涓浜-涓夊垎鍦
    --num;
   }. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
   else {
    ++num;
    ++ind;. from: 1point3acres.com/bbs
   }
  }
  return -1;
}
int Tetris(int w, int h, vector<vector<pair<int, int>>>& pieces) {
  vector<vector<bool>> grid(h + 2, vector<bool>(w + 2, false));
  for (int i = 0; i < h + 2; ++i) {
   grid[i][0] = grid[i][w + 1] = true;
  }
  for (int j = 0; j < w + 2; ++j) {
   grid[0][j] = grid[h + 1][j] = true;
  }
  int row = pieces.size();
  return helper(grid, w + 2, h + 2, pieces, 0, row, 0, 0);
}
};
int main() {.1point3acres缃
Solution s;
vector<vector<pair<int, int>>> pieces = { { { 0, 0 }, { 1, 0 }, { 2, 0 }, { 3, 0 } },
{ { 0, 0 }, { 1, 0 }, { 2, 0 }, { 2, 1 } }, { { 0, 0 }, { 1, 0 }, { 0, 1 }, { 1, 1 } },
{ { 0, 0 }, { 1, 0 }, { 0, 1 }, { 2, 0 } }, { { 0, 0 }, { 1, 0 }, { 2, 0 }, { 2, -1 } },
{ { 0, 0 }, { 1, 0 }, { 1, -1 }, { 2, -1 } }, { { 0, 0 }, { 1, 0 }, { 1, -1 }, { 2, -1 } },
{ { 0, 0 }, { 1, 0 }, { 1, -1 }, { 1, -2 } }, { { 0, 0 }, { 1, 0 }, { 1, 1 }, { 0, 1 } } };
cout << s.Tetris(6, 6, pieces) << endl;
return 0;. From 1point 3acres bbs
}
江渚散人 发表于 2017-12-3 04:17:59 | 显示全部楼层
akuna的俄罗斯方块题我是投python岗遇到的,一定要用python写,我dfs做出来了
回复 支持 反对

使用道具 举报

 楼主| leonard_lin 发表于 2017-12-3 05:49:16 | 显示全部楼层
原来如此,我python用得少。。。用的时候基本上是做machine learning模型
回复 支持 反对

使用道具 举报

本版积分规则

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2017-12-15 14:39

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表