到了TIT创意园,第一眼进去就觉得。。。我去那么高大上的。。。一栋栋砖厂房内部都改装成了高级办公室,以后如果能在这里工作。。死以足惜 = =
好了废话不多说,找到了腾讯的4号微信楼,拿了牌子到了3号楼等面试官
过了10分钟,下来了一位相貌平凡的男生,大概有个26岁左右。。叫我和他一起上楼,还笑着问我,今天没有上课啊~(我翘课来面试的 = = 哈哈)
然后坐到一个咖啡桌上,我递了一份简历给他,他给了一份题给我做,笑着说:“45分钟后我回来哦~”
我拿起题目一看= =我去,3道题都是考察编程的(我面试的方向是ios)
应该都是用c++来考察的
1、请你写出memcpy函数的实现方法:拷贝函数
2、请您写出atoi函数的实现方法
3、请写出双向链表的删除目标值nVal的方法,并输出删除数量
拿到题后,第一和第三题稍微有些把握。。但是第2题确实有些虚= =毕竟把字符串转整型我把它考虑得太复杂了= =(我没有想过手机去百度查,没意思,虽然周围没人,但是面试一定要诚实!)
三道题写完之后,1小时过去了。。他回来开始问我有关题目的东西(第一第三题有清晰思路,第一题答得稍微完整一些,第三题二了,居然参数里搞了一个尾指针= =我当时真的太紧张了,因为以为他要给我一些objc的问题。。。没想到全部都是c和c++的概念,第二题只是大概写了思路)
他也没有直接说我答得不好,开始找我代码里的错,然后我顺着代码讲我的思路。。到了错的地方,他便开始提醒我哪里有问题,并且问我一些基础知识,比如什么是&符号,内存字节数,深复制和浅复制等等。。然后开始对照简历问我项目的事情,我就如实回答(真的如实没有一句假话)
不过当时真的一个项目做太久了,有实现一个多通道上下文的滤镜算法,他问我怎么实现黑白算法的参数,我顿时懵了,参数我是对照参数表来填的,方法确实是我写的。。但是我忘了参数的具体数字。。他便问这个东西是不是你自己做的,我说是。。(不过能看出他有些失望吧)但是面试官真的挺好人,和我说,做过的东西一样要去牢牢掌握他,不然就失去项目的意义和学习的意义。我挺惭愧的,后来我还聊了一些关于python、服务器后台的东西。
最后我们开始聊一些和技术没关的东西,我问师兄请问您是哪里的,为什么今天没有问objc的东西。。他说是华师的(虽然我是华工的,但是真的自愧不如),他说,其实挺多同伴以前都是后台开发,后来转型做ios,技术不在于你有多高深,而是你对基础的掌握程度!(赞!!!)
最后他送走我,我一路上都在反思,不管结果如何,我今天都是收获颇多。
你对自己所学到的东西有没有用心?
你对自己的知识掌握如何?
你值得一份offer吗?
综合那么多,我也找到了以后学习的方向和动力,无论如何,感谢这位名叫jake的面试官!
PS:面试结果我会在回复里说的~应该没什么希望了吧= =代码写的漏洞百出啊!
(下面是重新审视这三题的答案:)
1、
2、
int atoi (char s[]);
int main(void )
{
char s[100];
gets(s);
printf("integer=%d\n",atoi(s));
return 0;
}
int atoi (char s[])
{
int i,n,sign;
for(i=0;isspace(s[i]);i++)//跳过空白符;
sign=(s[i]=='-')?-1:1;
if(s[i]=='+'||s[i]==' -')//跳过符号
i++;
for(n=0;isdigit(s[i]);i++)
n=10*n+(s[i]-'0');//将数字字符转换成整形数字,关键步骤= =唉,我真是。。
return sign *n;
}
2、
void *Memcpy(void *dst, const void *src, size_t size)
{
char *psrc;
char *pdst;
if(NULL == dst || NULL == src)
{
return NULL;
}
if((src < dst) && (char *)src + size > (char *)dst) // 自后向前拷贝
{
psrc = (char *)src + size - 1;
pdst = (char *)dst + size - 1;
while(size--)
{
*pdst-- = *psrc--;
}
}
else
{
psrc = (char *)src;
pdst = (char *)dst;
while(size--)
{
*pdst++ = *psrc++;
}
}
return dst;
}
3、
DLinkList DLinkListDelete(DLinkList L,int i)
{
int tempi = 1;
DLinkList p; //p为查找结点。
p = L->next;
while((tempi++) != i && p != NULL)
{
p = p->next;
}
if(p == NULL) //检查是不是在双链表中的位置
printf("位置不合法。\n");
else if(p->next == NULL) //最后一个结点特殊处理,原因最后一个结点p->next没有prior
{
p->prior->next = NULL;
free(p);
}
else //进行删除操作
{
p->prior->next = p->next;
p->next->prior = p->prior;
free(p);
}
}
然后在调用DLinkListDelete的过程中给一个int i值,不断记录删除的次数就好!
= = 欲哭无泪
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.