2018网易游戏雷火盘古实习生笔试

看了往年的题目,今年一如既往的是4个题目,讲道理都是区域赛签到题水平,或稍微难些,不及铜牌题。

虽然把机械键盘从公司拿回来了,但是手太生了,发挥的有点失常,估计是与网易游戏无缘了T_T。去年秋季九一八就让我去南京笔试,我那阵子在泡图书馆干大事,实在没空,错过了一次机会,这次又没抓住,哎。。。

1.第一个题,扔硬币,10000个硬币排成一排,每次选一个区间翻面,翻1000次,可以用树状数组区实现间加减法,讲道理如果暴力1kw复杂度人品好能过吧,没试过。

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

int n,m;
int coins[10009];
int ans[10009];
int main(){
    while(cin>>n>>m){
        memset(coins,0,sizeof(coins));
        memset(ans,0,sizeof(ans));
        int MAXN=0;
        for(int i=0;i


2.给三角形三个点,并给出一个新点,判断在不在三角形内,如果在内部求这个新点的插值。对插值不太熟悉,我连这玩意的定义公式都忘了,目测计算机图形学讲过?没想到好办法,跳过去了,没写,最后也没写这个题,光纠结最后一个题了。判断点在三角形内,可以用该点的y坐标横着切一刀,比较一下左右交点的奇偶性就行了。

3.100个村子之间有路,求出一共有几个联通的集合,-1之后算出至少新修几条路能使其全部联通。数据量太小了,一开始想用并查集,后来觉得简直大材小用,随便搞搞,dfs一下暴力一下就行了。

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

int n,m;

vectorG[109];
bool used[109];

void dfs(int root){

    used[root]=1;
    for(int i=0;i>n>>m){
        memset(used,0,sizeof(used));
        for(int i=0;i<101;i++){
            G[i].clear();
        }

        for(int i=0;i>a>>b;
            G[a].push_back(b);
            G[b].push_back(a);
        }
        int ans=0;
        for(int i=1;i<=n;i++){
            if(used[i]==0){
                dfs(i);
                ans++;
            }
        }
        cout<


4.最后一个题,开始写的时候还有一个多小时,浪费的时间有点多。给出一个长度50的大写字母组成的字符串,每次能打印连续的同样字母的字符串,后打的可以覆盖前面的,问至少打印几次能打印完。这个题是典型的区间DP,一开始我自己出的测试样例水了,觉得贪心就能过,然后交了一发贪心的,结果case通过率2%,不知道算不算罚时啊。这个题挂了之后我就去研究第二个题了,第二个题没研究出来又回来研究这个题,然后慢慢敲,剩了5分钟才研究出来公式,之前少考虑了两边夹中间的,然后这个题没写完就到点了,最后把样例都过不了的代码交上去了- -。时间截止之后,我又把这题代码写完了,自己出的样例都能过了。。。哎。。。再给我半个小时就好了,自己太水了。

#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 
using namespace std;

char S[58];
int dp[55][55];
int main(){
    while(scanf("%s",S)!=EOF){
        int l=strlen(S);
        for(int i=0;i=l)continue;
                if(S[k]==S[k-1]){
                    dp[j][k]=min(dp[j][k],dp[j][k-1]);
                }
                if(S[j]==S[j+1]){
                    dp[j][k]=min(dp[j][k],dp[j+1][k]);
                }
                if(S[j]==S[k]&&l>=3){
                    dp[j][k]=min(dp[j][k],dp[j+1][k-1]+1);
                }
                dp[j][k]=min(dp[j][k],dp[j][k-1]+1);
                dp[j][k]=min(dp[j][k],dp[j+1][k]+1);


                for(k=j+1;k<=j+i&&k




你可能感兴趣的:(刷题)