最后
经过日积月累, 以下是小编归纳整理的深入了解Java虚拟机文档,希望可以帮助大家过关斩将顺利通过面试。
由于整个文档比较全面,内容比较多,篇幅不允许,下面以截图方式展示 。
由于篇幅限制,文档的详解资料太全面,细节内容太多,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
输入样例:
6 5
John
Robert
Frank
Andrew
Nancy
David
Robert is a child of John
Robert is an ancestor of Andrew
Robert is a sibling of Nancy
Nancy is the parent of Frank
John is a descendant of Andrew
输出样例:
True
True
True
False
False
===================================================================
用map容器记录空格,再用一个map来记录关系 ,
思路分析:
第一步:
x是y的孩子---------> y比x多两个空格
x是y的父母---------> x比y少两个空格
x是y的兄弟姐妹-----> 空格数相等
x是y的后代---------> 只要x的空格数比y 多就可以
x是y的祖先---------> y比x多的空格数 大于等于2
第二步:
考虑 关系 代码当中有解释 很炫的
===================================================================
//思路分析:
//第一步:
//x是y的孩子---------> y比x多两个空格
//x是y的父母---------> x比y少两个空格
//x是y的兄弟姐妹-----> 空格数相等
//x是y的后代---------> 只要x的空格数比y 多就可以
//x是y的祖先---------> y比x多的空格数 大于等于2
//第二步:
//考虑 关系
//
//X is a child of Y
//X is the parent of Y
//X is a sibling of Y
//X is a descendant of Y
//X is an ancestor of Y
#include<bits/stdc++.h>
using namespace std;
map<string,string>father;//存关系 father[孩子] = 双亲
int spaceNum(string str,int cnt){ //计算空格数
for( int i = 0; i < str.size(); i++ )
{
if(str[i] == ’ ')
cnt++;
}
return cnt;
}
int judgment(string str1,string str2){ //往上找爹 用于解决测试点三
while( father[str1] != str2 ){
if(father[str1] == “zuxian”)
break;
string temp;
temp = father[str1];
str1 = temp;
}
if(father[str1] == str2 )
return 1;
else
return 0;
}
int main()
{
map<string,int>m;
map<string,int>:: iterator t;
vectorv(110);//存名字
int N,M;
cin >> N >> M;
getchar();//出去换行符的干扰
for( int i = 0; i < N; i++ )
{
string str;
getline(cin,str);
int count = spaceNum(str,0);
if( count == 0 )
{
father[str] = “zuxian”;
v[0] = str; //如果不给容器的大小 即vectorv(N); 则需要用v.push_back();
// v.push_back(str);
}
else{
string str1 = str.substr(count);//这里为截取字符串 将空格去掉
m[str1] = count;//这里count 可能会重复 但没关系,map当中不存在键值重复,存在关键值重复
father[str1] = v[count/2 -1]; //这里非常巧妙,学大佬的 因为孩子的空个数总是比双亲少两个 count/2-1这样 就 可 以 将 双亲和孩子yiyi对应上
v[count/2] = str1; //当空格数相等时,会发生覆盖
}
}
for( int i = 0; i < M; i++ )
{
string a,b,c,d,e,f;
cin >> a >> b >> c >> d >> e >> f;
if( d == “child” )
{
if(m[a] - m[f] == 2 && father[a] == f)// father[a] = f a的双亲是f
cout << “True” << endl;
else
cout << “False” << endl;
}
if( d == “parent” )
{
if(m[f] - m[a] == 2 && father[f] == a)
cout << “True” << endl;
else
cout << “False” << endl;
}
if( d == “sibling” )
{
if(m[a] - m[f] == 0 && father[a] == father[f])
cout << “True” << endl;
else
cout << “False” << endl;
}
if( d == “descendant” )
{
int a1 = judgment(a,f);
if( (m[a] - m[f] > 2 && a1 == 1) || father[f] == “zuxian” ) //如果这里的f是祖先的话 任何他的孩子 都是后代
cout << “True” << endl;
else
最后
最后,强调几点:
- 1. 一定要谨慎对待写在简历上的东西,一定要对简历上的东西非常熟悉。因为一般情况下,面试官都是会根据你的简历来问的; 能有一个上得了台面的项目也非常重要,这很可能是面试官会大量发问的地方,所以在面试之前好好回顾一下自己所做的项目;
- 2. 和面试官聊基础知识比如设计模式的使用、多线程的使用等等,可以结合具体的项目场景或者是自己在平时是如何使用的;
- 3. 注意自己开源的Github项目,面试官可能会挖你的Github项目提问;
我个人觉得面试也像是一场全新的征程,失败和胜利都是平常之事。所以,劝各位不要因为面试失败而灰心、丧失斗志。也不要因为面试通过而沾沾自喜,等待你的将是更美好的未来,继续加油!
以上面试专题的答小编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目。
面试答案
编案整理成面试文档了,文档里有答案详解,以及其他一些大厂面试题目。**
面试答案
[外链图片转存中…(img-WV3AmIcL-1715799693074)]
[外链图片转存中…(img-e3JhhDI4-1715799693074)]
[外链图片转存中…(img-XjNHz0I7-1715799693074)]