面试总体感觉还可以,上来先做了自我介绍,然后问了一下简历上的项目,用到的一些技术栈都有哪些,具体是怎么实现的,这块聊的都比较轻松
然后就开始做了两道题:
第一题、判断两条直线是否相交,主要是想看面试者是否知道边界值。
思路:判断两条直线是否相交,主要是看两条直线的k是否相等,如果相等的话还要看他们的b是否相等,如果b相等,则两条直线重合,如果b不相等,则两条直线只能平行;反之,若k不相等说明他们相交。
用代码实现:
#include <iostream>
using namespace std;
struct node{
double k;
double b;
};
int main()
{
struct node y1;
double x1=2.0,y1=3.0;
double x2=4.0,y2=5.0;
if(x1-x2 != 0)
{
y1.k=(y1-y2) / (x1-x2);
}
y1.b=y1-y1.k *x1;
struct node y2;
double xx1=2.0,yy1=3.0;
double xx2=4.0,yy2=5.0;
if(xx1-xx2 != 0)
{
y2.k=(yy1-yy2)/(xx1-xx2);
}
y2.b=yy1-y2.k * xx1;
if(y1.k==y2.k)
{
if(y1.b==y2.b)
{
cout<<"两条直线重合"<<endl;
}
else
{
cout<<"两条直线平行"<<endl;
}
}
else
cout<<"两条直线相交"<<endl;
return 0;
}
不过,也是在面试官的几次提示之下完成的。
第二题:给定一个二维矩阵,将这个二维矩阵旋转90°后的二维矩阵输出是什么。
思路:当时紧张了,忘了如何初始化这个二维矩阵了,只记得定义,所以这次吸取教训吧
代码如下:
#include <iostream>
#include <vector>
using namespace std;
int main()
{
vector<vector<int>>path(3,vector<int>(3,0));
path={{1,3,5},{7,9,11},{13,15,17}};
for(int i=0;i<path.size();i++)//这个是遍历行
{
for(int j=0;j<path[i].size();j++)//遍历列
{
cout<<path[i][j]<<" ";
}
cout<<endl;
}
for(int i=0;i<path.size();i++)
{
for(int j=0;j<path[i].size();j++)
{
cout<<path[2-j][i]<<" ";//90°
cout<<path[2-i][2-j]<<" ";//180°
cout<<path[j][2-i]<<" ";//270°
}
cout<<endl;
}
}
以上就是本次面试的全部过程。