微软面试

微软软件工程师面试

本次去的是上海紫竹科技园面试的苏州微软,一共有两面,总的感觉是,外企比较注重英语,还有写代码的细节。
一面:英文自我介绍+两道算法。
当时有些匆忙,很晚才赶到闵行,太偏远了,没有准备好英文自我介绍,有些卡壳,凡事实现都要多了解。
第一题
求两个日期差多少天,这个题我想复杂了,把两个日期相减,要考虑闰年,月份的天数,容易出错,不妨直接计算他们距离公元0年的天数,直接相减。

#include<iostream>
using namespace std;
struct Date
{
	int y;//year
	int m;//month
	int d;//day in month
};
bool isLeap(int y)//判断是否是闰年
{
	return y%4==0&&y%100!=0||y%400==0;//真返回为1,假为0
}
int daysOfMonth(int y,int m)
{
	int day[12]={31,28,31,30,31,30,31,31,30,31,30,31};
	if(m!=2)
		return day[m-1];
	else 
		return 28+isLeap(y);
}
int daysOfDate(Date d)//计算一共的天数
{
	int days=d.d;
	for(int y=1;y<d.y;y++)//计算年
		days+=365+isLeap(y);
	for(int m=1;m<d.m;m++)//计算月
		days+=daysOfMonth(d.y,m);
	//days+=d.d;
	return days;
}
int main()
{
	Date d1,d2;
	cout<<"intput 2 dates(yyyy mm dd):";
	cin>>d1.y>>d1.m>>d1.d;
	cin>>d2.y>>d2.m>>d2.d;
	int days1=daysOfDate(d1);
	int days2=daysOfDate(d2);
	cout<<"difference:"<<days2-days1<<endl;
	cout<<"weekday"<<days1%7<<"\t"<<days2%7<<endl;
	return 0;
}
入代码片

第二题:在长字符串a中查找短字符串b出现的次数,其中在bbb中查找bb算一次,即不允许overlap,这一题做出来了,但是有两个小细节写的有点问题。

public int StringFind(String a, String b){
        int la = a.length(), lb = b.length();
        char[] aa = a.toCharArray(), bb = b.toCharArray();
        int count = 0;
        for (int i = 0; i < la - lb + 1; i++) {
            if (equal(aa, i, i + lb, bb)) {
                count++;
            }
        }
        return count;
    }

    private  boolean equal(char[] aa, int i, int i1, char[] bb) {
        int k = 0;
        for (int j = i; j < i1; j++) {
            if (aa[j] != bb[k++]) {
                return false;
            }
        }
        return true;
    }

二面:首先是英文自我介绍和介绍北京,两道算法,都不难,就是一些细节,还有一个英文邮件回复的问题。 本人的口语确实太差了,没有提前准备,又卡壳了。。。
第一题:请将下列一句话倒着念,“I am a student" 转换为“student a am I” ,每个单词之间以一个空格相隔开,不存在前置或者末尾的空格。

  private static String reverse(String a) {
        List<String> b = new ArrayList<>();
        int pre = 0;
        for (int i = 0; i < a.length(); i++) {
            if (a.charAt(i) == ' ') {
                b.add(a.substring(pre, i ));
                pre = i + 1;
            }
        }
        b.add(a.substring(pre));
        StringBuilder res = new StringBuilder();
        for (int i = b.size() - 1; i > 0; i--) {
            res.append(b.get(i));
            res.append(' ');
        }
        res.append(b.get(0));
        return res.toString();
    }

第二题:请用正则表达式对用户输入的邮箱进行校验。
要求:大小写字母、数字、下划线、减号、点 + @ + 大小写字母、数字、点、减号 + . (点之前不能是点) + 大小写字母、数字 ,长度>=2并且<=6.

题解:
string reg=/^[a-zA-Z0-9_.-]+@[a-zA-Z0-9-]+(\.[a-zA-Z0-9-]+)*\.[a-zA-Z0-9]{2,6}$/;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值