2018年爱奇艺校招笔试

  我选的是前端方向,所以编程题的题目也比较简单,但是坑很多呀,不知道错在哪,最后没办法直接用最暴力的方法AC了。

 

  笔试分为选择和编程,选择20个,每个三分,编程题两道每道20分。

  选择题考点:

    1、数据结构(包括大顶堆、希尔排序、B-树、以及hash)

    2、计算机网络(只考了一两题,TCP和UDP)

    3、数据库(表设计)

    4、HTML/CSS(CSS3、翻书效果怎么实现、一张图上映射多个区域)

    5、JS(禁止前进和后退、作用域)

  我有印象的应该就是作用域的这个题了:

    下面这个代码输出什么(如果我没记错,应该就是原题目)

<!DOCTYPE html>
<html>
<script>
    function func() {
        document.write(a);
        document.write(fun);
        var a = 1;
        function fun(){
            return 2;
        }
    }
</script>

<body>

    <a onclick="func()">点击我</a>
</body>
</html>

  编程题:其实都挺简单的,但是第一题我没想对坑点,我想到的点似乎都没这样的数据。

    第一题:

幸运ID
时间限制:C/C++语言 1000MS;其他语言 3000MS
内存限制:C/C++语言 131072KB;其他语言 655360KB
题目描述:
小C有一张票,这张票的ID是长度为6的字符串,每个字符都是数字,他想让这个ID变成他的辛运ID,所以他就开始更改ID,每一次操作,他可以选择任意一个数字并且替换它。

如果这个ID的前三位数字之和等于后三位数字之和,那么这个ID就是辛运的。你帮小C求一下,最少需要操作几次,能使ID变成辛运ID

输入
输入只有一行,是一个长度为6的字符串。

输出
输出这个最小操作次数


样例输入
000000
样例输出
0

Hint
输入样例2
000018

输出样例2
1

样例解释:将前三位任意一个改为9即可满足条件,操作数为1

AC代码:(直接暴力贪心解决)

// Asimple
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <string>
#include <cstring>
#include <cmath>
using namespace std;
typedef long long ll;const int maxn = 100000+5;
ll n, m, T, len, cnt, num, ans, Max, k;
string str;
int max_a[3], min_a[3];

void input(){
    while( cin >> str ) {
        int sum1 = 0, sum2 = 0;
        for(int i=0; i<6; i++) {
            if( i < 3 ) sum1 += (str[i]-'0');
            else sum2 += (str[i]-'0');
        }
        int cnt = abs(sum1-sum2);
        if( sum1>sum2 ) {
            for(int i=0; i<6; i++) {
                if( i<3 ) max_a[i] = max((str[i]-'0'), 9-(str[i]-'0'));
                else min_a[i-3] = max((str[i]-'0'), 9-(str[i]-'0'));
            }
        } else {
            for(int i=0; i<6; i++) {
                if( i>=3 ) max_a[i-3] = max((str[i]-'0'), 9-(str[i]-'0'));
                else min_a[i] = max((str[i]-'0'), 9-(str[i]-'0'));
            }
        }
        sort(max_a, max_a+3); sort(min_a, min_a+3);
        int res = 0, j = 2, i = 2;
        while( cnt > 0 ) {
            int te = max(max_a[i], min_a[j]);
            cnt -= te;
            if( te == max_a[i] ) i--;
            else j --;
            res ++;
        }
        cout << res << endl;
    }
}

int main() {
    input();
    return 0;
} 

91%代码(第一版就是91%,之后改的只降不升,最后十分钟无能为力只能暴力AC,求大神找出坑点)

// Asimple
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <queue>
#include <vector>
#include <string>
#include <cstring>
#include <stack>
#include <set>
#include <map>
#include <cmath>
using namespace std;
typedef long long ll;const int maxn = 100000+5;
ll n, m, T, len, cnt, num, ans, Max, k;
//vector<int> a[maxn];
string str;
int a[10];

void input(){
    while( cin >> str ) {
        memset(a, sizeof(a), 0);
        int sum1 = 0, sum2 = 0;
        for(int i=0; i<6; i++) {
            if( i < 3 ) sum1 += (str[i]-'0');
            else sum2 += (str[i]-'0');
        }
        int cnt = abs(sum1-sum2);
        int res = cnt/9 + (cnt%9!=0);
        // 下面这个判断是我想的坑点
        // 但是没有下面的语句一样也是91%
        if( cnt == 9 ) {
            if( a[0]+a[9] == 0 ) res++;
        } else if( cnt == 18 ) {
            if( a[0]+a[9]<2 ) res ++;
        }
        cout << res << endl;
    }
    // pas;
}

int main() {
    input();
    return 0;
} 

第二题:


局长的食物
时间限制:C/C++语言 1000MS;其他语言 3000MS
内存限制:C/C++语言 131072KB;其他语言 655360KB
题目描述:
局长有N种食物,每种食物有Ai份。

每天局长会吃一份食物,或者买一份食物(即每天只能进行吃或买其中的一种动作),这样过了M天

现在局长想知道M天后第p种食物的份数排名(从大到小,相同算并列,例如3 3 2,则排名为1 1 3)

N,M,P<=100,Ai<=1000

输入
第一行N M P

第二行N个数Ai

接下来M行,每行A i或者B i分别表示买一份食物i,吃一份食物i

输出
一个答案


样例输入
3 4 2
5 3 1
B 1
A 2
A 2
A 3
样例输出
1

简单排序,注意名次的增加就好

AC代码:

// Asimple
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <queue>
#include <vector>
#include <string>
#include <cstring>
#include <stack>
#include <set>
#include <map>
#include <cmath>
#define INF 0x3f3f3f3f
#define debug(a) cout<<#a<<" = "<<a<<endl
#define test() cout<<"============"<<endl
#define CLS(a,v) memset(a, v, sizeof(a))
#define pas system("pause")
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
int dx[] = {-1,1,0,0,-1,-1,1,1}, dy[]={0,0,-1,1,-1,1,1,-1};
const int maxn = 1000+5;
const ll mod = 1000000007;
ll n, m, T, len, cnt, num, ans, Max, k;
//vector<int> a[maxn];
struct node{
    int ind;
    int sum;
    bool operator < (const node& a) const {
        return sum>a.sum;
    }
};
node a[maxn];

void input(){
    int p;
    while( cin >> n >> m >> p ) {
        for(int i=1; i<=n; i++) {
            cin >> a[i].sum;
            a[i].ind = i;
        }
        char ch;
        while( m -- ) {
            cin >> ch >> num;
            if( ch == 'A' ) {
                a[num].sum ++;
            } else {
                if( a[num].sum>0) a[num].sum --;
            }
        }
        sort(a+1, a+n+1);
        int cnt = 0, te = 1;
        a[0].sum = -1;
        for(int i=1; i<=n; i++) {
            if( a[i].sum !=a[i-1].sum ) {
                cnt += te;
                te = 1;
            } else {
                te ++;
            }
            if( a[i].ind == p ) {
                cout << cnt << endl;
                break;
            }
        }
    }
    // pas;
}

int main() {
    input();
    return 0;
} 

 

posted @ 2018-09-15 12:19  Asimple  阅读(877)  评论(0编辑  收藏  举报