题解 | #整理房间#

整理房间

http://www.nowcoder.com/practice/c32f4c74446541a1ad2abbe54476681f

include <stdio.h>

include <math.h>

typedef struct node{
int x,y;
}node;
bool judge(int a1 ,int b1 ,int a2 ,int b2,int a3,int b3,int a4,int b4){
int dis[6];
dis[0] = (a1-a2)(a1-a2)+(b1-b2)(b1-b2);
dis[1] = (a1-a3)(a1-a3)+(b1-b3)(b1-b3);
dis[2] = (a1-a4)(a1-a4)+(b1-b4)(b1-b4);
dis[3] = (a2-a3)(a2-a3)+(b2-b3)(b2-b3);
dis[4] = (a2-a4)(a2-a4)+(b2-b4)(b2-b4);
dis[5] = (a3-a4)(a3-a4)+(b3-b4)(b3-b4);
int a = dis[0],b = -1;
int cnt1 = 1,cnt2 = 0;
for(int i=1;i < 6;++i){
if(dis[i] == a){
++cnt1;
}else if(dis[i] != a && b == -1){
b = dis[i];
++cnt2;
}else if(dis[i] == b){
++cnt2;
}else if(dis[i] != a && dis[i] != b){
return false;
}
}
if((cnt1 == 4 && cnt2 == 2 && a != 0 && b != 0) || (cnt1 == 2 && cnt2 == 4 && a != 0 && b != 0)){
return true;
}else{
return false;
}
}
int main(){
int n;
while(scanf("%d",&n) != EOF){
int ai[4],bi[4],ci[4],di[4];
while(n--){
for(int i=0;i < 4;++i){
scanf("%d %d %d %d",&ai[i],&bi[i],&ci[i],&di[i]);
}
int a1[4] = {ai[0]},b1[4] = {bi[0]};
int a2[4] = {ai[1]},b2[4] = {bi[1]};
int a3[4] = {ai[2]},b3[4] = {bi[2]};
int a4[4] = {ai[3]},b4[4] = {bi[3]};
for(int i=1;i < 4;++i){
a1[i] = -b1[i-1] + ci[0] + di[0];
b1[i] = a1[i-1] - ci[0] + di[0];
}
for(int i=1;i < 4;++i){
a2[i] = -b2[i-1] + ci[1] + di[1];
b2[i] = a2[i-1] - ci[1] + di[1];
}
for(int i=1;i < 4;++i){
a3[i] = -b3[i-1] + ci[2] + di[2];
b3[i] = a3[i-1] - ci[2] + di[2];
}
for(int i=1;i < 4;++i){
a4[i] = -b4[i-1] + ci[3] + di[3];
b4[i] = a4[i-1] - ci[3] + di[3];
}
int min = -1 , cnt = 0,cnt1 = 0,cnt2 = 0,cnt3 = 0,cnt4 = 0;
for(int i1=0;i1 < 4;++i1,++cnt1){
cnt2 = 0;
cnt3 = 0;
cnt4 = 0;
for(int i2 = 0;i2 < 4;++i2, ++cnt2){

                cnt3 = 0;
                cnt4 = 0;
                for(int i3=0;i3 < 4;++i3,++cnt3){

                    cnt4 = 0;
                    for(int i4 = 0;i4 < 4;++i4){

                        //printf("%d %d %d %d %d %d %d %d\n",a1[i1],b1[i1],a2[i2],b2[i2],a3[i3],b3[i3],a4[i4],b4[i4]);
                        if(!judge(a1[i1],b1[i1],a2[i2],b2[i2],a3[i3],b3[i3],a4[i4],b4[i4])){
                            ++cnt4;
                        }else{
                            cnt = cnt1 + cnt2 + cnt3 + cnt4;
                            if(min > cnt || min == -1){
                                min = cnt;

                            }
                        }
                    }
                }
            }
        }
        printf("%d\n",min);
    }

}
return 0;

}

全部评论

相关推荐

我是985研究生,最近学校在组织开题,大家都在非常紧张地准备,但我一直进入不了状态,很想做但是心又很浮躁。但我的室友们感觉都非常认真,每天醒来就开始看论文,睡着前最后一件事还是在看论文,我非常焦虑。我感觉自己甚至有点把大家当做假想敌了。这种比较心态还存在于生活的各种方面:看到有钱的同学会非常羡慕,看到朋友圈里面环游世界的留学生同学也会羡慕,看到那些工作后有自己的钱而过上较为阔绰的生活的时候还是羡慕,就仿佛只有自己一个人在阴暗爬行。而且这些比较是每时每刻的,为了不比较,我已经关闭了朋友圈,但是每次偶尔刷一下还是会难受很久。我知道比较是偷走幸福的小偷,但我好像控制不了,感觉自己是一个偷窥别人生活的...
若怜君欢:担心开题搞砸了,幻想拥有别人的生活,本质上是因为自卑,楼主小时候大概率是留守儿童或者父母关系很紧张,导致楼主没有安全感、焦虑、内耗。 这样的情况最好的办法就是建立自信和降低期待,建立自信不是一蹴而就,而是循序渐进,比如告诉自己允许自己第一次没把事情做好,失败了能搞清楚其中缘由而不是全盘否定自己,失败不是终点,放弃才是;降低期待只要记住一句话即可,能伴随你一生的,只有经验和学识,所以你对事情的态度应该更多地去思考它是否能带来学识和经验的增长,而不是仅仅用短期的利益作为唯一期待。 人生不是一成不变的,它是可以迭代更新的,去归纳总结自身的不足并结合实际去改进,去尝试一些新的思路和方法,不要固执钻牛角尖,也不要反复横跳,为自己设立一个高度聚集的精神内核,内核之上可以去尝试一切有利于自己更好的方式 以上就是我个人对生活的理解,共勉
点赞 评论 收藏
分享
03-10 14:19
已编辑
重庆邮电大学 前端工程师
球Offer上岸👑:测试也难求一面 逆天
点赞 评论 收藏
分享
评论
3
2
分享

创作者周榜

更多
牛客网
牛客企业服务