美团硬开笔试--小美架炮
#美团笔试# #牛客AI配图神器# 编程2题
只会暴力,复杂度O(n*max_x*max_y),不知道能不能通过,求教
// 在无限大的中国象棋棋盘中有n个炮,第i个炮的坐标是(xi,yi),攻击方式与中国象棋规则一致,每个炮只能攻击到间隔一个棋子的炮,不能打间隔两个及以上棋子的炮,请求出每个炮第一次能攻击到多少个炮。输入是:
// 6
// 0 0
// 0 1
// 0 2
// 1 0
// 2 0
// 3 0
// 输出是
// 2
// 0
// 1
// 1
// 1
// 1
#include
# include
#include
# define MAX_SIZE 1000
bool cannon[MAX_SIZE][MAX_SIZE];
int main()
{
typedef struct position {
int x;
int y;
int result;
} position_input;
position_input input_canno[MAX_SIZE];
int input_cannonnums;
int max_x=0, max_y=0;
scanf("%d", &input_cannonnums);
for(int i=0; i max_x){
max_x = input_canno[i].x;
}
if(input_canno[i].y > max_y){
max_y = input_canno[i].y;
}
}
for(int i=0; i=0; k--){
if(cannon[k][y] == 1){
for(int l=k-1; l>=0; l--){
if(cannon[l][y] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
// 纵向
for(int k=y+1; k<=max_y; k++){
if(cannon[x][k] == 1){
for(int l=k+1; l<=max_y; l++){
if(cannon[x][l] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
for(int k=y-1; k>=0; k--){
if(cannon[x][k] == 1){
for(int l=k-1; l>=0; l--){
if(cannon[x][l] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
}
for(int i=0; i
只会暴力,复杂度O(n*max_x*max_y),不知道能不能通过,求教
// 在无限大的中国象棋棋盘中有n个炮,第i个炮的坐标是(xi,yi),攻击方式与中国象棋规则一致,每个炮只能攻击到间隔一个棋子的炮,不能打间隔两个及以上棋子的炮,请求出每个炮第一次能攻击到多少个炮。输入是:
// 6
// 0 0
// 0 1
// 0 2
// 1 0
// 2 0
// 3 0
// 输出是
// 2
// 0
// 1
// 1
// 1
// 1
#include
# include
#include
# define MAX_SIZE 1000
bool cannon[MAX_SIZE][MAX_SIZE];
int main()
{
typedef struct position {
int x;
int y;
int result;
} position_input;
position_input input_canno[MAX_SIZE];
int input_cannonnums;
int max_x=0, max_y=0;
scanf("%d", &input_cannonnums);
for(int i=0; i max_x){
max_x = input_canno[i].x;
}
if(input_canno[i].y > max_y){
max_y = input_canno[i].y;
}
}
for(int i=0; i=0; k--){
if(cannon[k][y] == 1){
for(int l=k-1; l>=0; l--){
if(cannon[l][y] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
// 纵向
for(int k=y+1; k<=max_y; k++){
if(cannon[x][k] == 1){
for(int l=k+1; l<=max_y; l++){
if(cannon[x][l] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
for(int k=y-1; k>=0; k--){
if(cannon[x][k] == 1){
for(int l=k-1; l>=0; l--){
if(cannon[x][l] == 1){
input_canno[i].result++;
break;
}
}
break;
}
}
}
for(int i=0; i
全部评论
相关推荐
点赞 评论 收藏
分享
2025-12-28 16:32
重庆邮电大学 Java
程序员花海:1.技能放最后,来面试默认你都会,技能没啥用
2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的
3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单
4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价 点赞 评论 收藏
分享
2025-12-14 11:43
黑龙江大学 Java
用微笑面对困难:确实比较烂,可以这么修改:加上大学的qs排名,然后大学简介要写一些,然后硕士大学加大加粗,科研经历第一句话都写上在复旦大学时,主要负责xxxx,简历左上角把学校logo写上,建议用复旦大学的简历模板 点赞 评论 收藏
分享
查看1道真题和解析