基于C++的拼多多算法在线笔试题示例

本文实例讲述了基于C++的拼多多算法在线笔试题。分享给大家供大家参考,具体如下:

最近在狼厂实习中,很久没做题了。秋招第一发, 拼多多。。。  四个简单题,看到有些人竟然觉得难? 我来降一发自己的RP,这题目觉得难的,如果你拿到比我好的Offer,我是不服气的。。

四个题。。。其实我也就写了40分钟吧。。不过最后也没有满分, 390/400, 第三题不知道为嘛一直有10分过不了。。

更一下, 刚刚好像发现第三题。。。这个>号, 我写的是>= ....? 可是我看题目好像是 >= 呀。。。

第一题:

要求时间复杂度O(n), 空间复杂度O(1)。

那么其实答案有两种情况,最大的三个数相乘 || 最小的两个数 * 最大的数。  时间复杂度O(n),瞬间想到时间复杂度O(n)求k大的经典算法,分治法!

#include <cstdio>
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
const int N = 1e6 + 10;
long long a[N];
int k;
int partition(int l,int r) {
  while(l != r)
  {
    while(a[r] >= a[l] && r > l)
      r--;
    if(l == r)
      break;
    swap(a[r],a[l]);
    while(a[l] < a[r] && r > l)
      l++;
    if(l < r)
      swap(a[r],a[l]);
  }
  return l;
}
long long solve(int l,int r) {
  int now = partition(l,r);
  if(k < now)
    return solve(l,now-1);
  else if(k > now)
    return solve(now+1,r);
  else
    return a[now];
}
int main() {
  int n;
  while(~scanf("%d", &n)) {
    for(int i = 0; i < n; ++i) {
      scanf("%lld", &a[i]);
    }
    k = n - 1;
   long long x1 = solve(0, n-1);
    k = n - 2;
    long long x2 = solve(0, n-2);
    k = n - 3;
    long long x3 = solve(0, n-3);
    long long Ans = x1 * x2 * x3;
    if(n > 3) {
      k = 0;
      long long y1 = solve(0, n-1);
      k = 1;
      long long y2 = solve(0, n-2);
      Ans = max(Ans, y1*y2*x1);
    }
    printf("%lld\n", Ans);
  }
  return 0;
}

第二题:

大数相乘,模板题, 找了个模板。。。

#include <iostream>
#include <cstring>
#include <string>
#include <algorithm>
using namespace std;
const int N = 1e5 + 10;
string c1, c2;
int a[N], b[N], r[N];
void solve(int a[], int b[], int la, int lb) {
  int i, j;
  for(i = 0; i != N; i++) r[i] = 0;
  for(i = 0; i != la; i++)
  {
    for(j = 0; j != lb; j++)
    {
      int k = i + j;
      r[k] += a[i] * b[j];
      while(r[k] > 9)
      {
        r[k + 1] += r[k] / 10;
        r[k] %= 10;
        k++;
      }
    }
  }
  int l = la + lb - 1;
  while(r[l] == 0 && l > 0) l--;
  for(int i = l; i >= 0; i--) cout << r[i];
  cout << endl;
}
int main() {
  while(cin >> c1 >> c2)
  {
    int la = c1.size(), lb = c2.size();
    for(int i = 0; i != la; i++)
      a[i] = (int)(c1[la - i - 1] - '0');
    for(int i = 0; i != lb; i++)
      b[i] = (int)(c2[lb - i - 1] - '0');
    solve(a, b, la, lb);
  }
  return 0;
}

第三题:

贪心啊, 我是按照 尽量满足最小人的需求来贪心的。。。一直90%?  有人是用尽量使用掉最大的巧克力来贪的,100%, 来个反例好不好?

#include <cstdio>
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
const int N = 3e6 + 10;
long long w[N], h[N];
int main() {
  int n, m;
  while(~scanf("%d", &n)) {
    for(int i = 0; i < n; ++i) {
      scanf("%lld", &h[i]);
    }
    scanf("%d", &m);
    for(int i = 0; i < m; ++i) {
      scanf("%lld", &w[i]);
    }
    sort(h, h + n);
    sort(w, w + m);
    int Ans = 0;
    for(int i = 0, j = 0; i < n && j < m; ) {
      if(w[j] >= h[i]) {
        ++Ans;
        ++i, ++j;
      }
      else {
        ++j;
      }
    }
    printf("%d\n", Ans);
  }
  return 0;
}

第四题:

迷宫问题, 有趣的是多了一把钥匙。。。  一看门不超过10个。。。M, N <=100...想了想状态数。。。直接状态压缩吧。。  之后就是一个非常暴力可耻的状态压缩bfs。。。然后就一发AC了。。

#include <cstdio>
#include <iostream>
#include <string>
#include <queue>
#include <map>
#include <algorithm>
using namespace std;
const int N = 110;
char mz[N][N];
bool vis[N][N][N*10];
int fx[4] = {0, 0, 1, -1};
int fy[4] = {1, -1, 0, 0};
int m, n;
map<char, int> key;
struct node {
  int x, y, cnt, sta;
  node():cnt(0), sta(0) {}
};
queue<node> que;
int bfs(int sx, int sy, int ex, int ey) {
  while(!que.empty()) que.pop();
  node tmp;
  tmp.x = sx, tmp.y = sy;
  que.push(tmp);
  while(!que.empty()) {
    node p = que.front();
    if(p.x == ex && p.y == ey) {
      return p.cnt;
    }
    que.pop();
    for(int i = 0; i < 4; ++i) {
      int newx = p.x + fx[i];
      int newy = p.y + fy[i];
      if(newx < 0 || newx >= m || newy < 0 || newy >= n) continue;
      if(mz[newx][newy] == '0') continue;
      int sta = p.sta;
      if(mz[p.x][p.y] >= 'a' && mz[p.x][p.y] <= 'z') {
        sta |= (1<<key[mz[p.x][p.y]]);
      }
      if(vis[newx][newy][sta]) continue;
      if(mz[newx][newy] >= 'A' && mz[newx][newy] <= 'Z') {
        if((sta & (1<<(key[mz[newx][newy] - 'A' + 'a'])))== 0) {
          continue;
        }
      }
      vis[newx][newy][sta] = true;
      tmp.x = newx, tmp.y = newy, tmp.cnt = p.cnt + 1, tmp.sta = sta;
      que.push(tmp);
    }
  }
  return -1;
}
int main() {
  while(~scanf("%d %d", &m, &n)) {
    int sx, sy, ex, ey;
    int cnt = 0;
    for(int i = 0; i < m; ++i) {
      scanf("%s", mz[i]);
      for(int j = 0; j < n; ++j) {
        if(mz[i][j] == '2') {
          sx = i, sy = j;
        }
        if(mz[i][j] == '3') {
          ex = i, ey = j;
        }
        if(mz[i][j] >= 'a' && mz[i][j] <= 'z') {
          key[mz[i][j]] = cnt++;
        }
      }
    }
    for(int i = 0; i < m; ++i) {
      for(int j = 0; j < n; ++j) {
        for(int s = 0; s < (1<<cnt); ++s) {
          vis[i][j][s] = false;
        }
      }
    }
    int Ans = bfs(sx, sy, ex, ey);
    printf("%d\n", Ans);
  }
  return 0;
}

希望本文所述对大家C++程序设计有所帮助。

(0)

相关推荐

  • c++ 快速排序算法【过程图解】

    第一.算法描述 快速排序由C. A. R. Hoare在1962年提出,该算法是目前实践中使用最频繁,实用高效的最好排序算法, 快速排序算法是采用分治思想的算法,算法分三个步骤 1.从数组中抽出一个元素作为基数v(我们称之为划界元素),一般是取第一个.最后一个元素或中间的元素 2.将剩余的元素中小于v的移动到v的左边,将大于v元素移动到v的右边 3.对左右两个分区重复以上步骤直到所有元素都是有排序好. 第二.算法实现 /*序列划分函数*/ int partition(int a[], int p

  • C++使用一个栈实现另一个栈的排序算法示例

    本文实例讲述了C++用一个栈实现另一个栈的排序算法.分享给大家供大家参考,具体如下: 题目: 一个栈中元素类型为整型,现在想将该栈从顶到底按从小到大的顺序排序,只许申请一个辅助栈. 除此之外,可以申请新的变量,但不能申请额外的数据结构.如何完成排序? 算法C++代码: class Solution { public: //借助一个临时栈排序源栈 static void sortStackByStack(stack<int>& s) { stack<int>* sTemp =

  • C++使用递归函数和栈操作逆序一个栈的算法示例

    本文实例讲述了C++使用递归函数和栈操作逆序一个栈的算法.分享给大家供大家参考,具体如下: 题目: 一个栈依次压入1.2.3.4.5,那么栈顶到栈底分别为:5.4.3.2.1. 将这个栈逆置后栈顶到栈底分别为1.2.3.4.5. 用递归函数来实现,不能用其他数据结构. 解题思路及代码 1.递归函数一:将栈的栈底元素一个个返回并移除. 2.递归函数二:逆序栈,调用递归函数一实现. C++实现: class Solution { public: //递归函数一 static int getAndRe

  • C++实现的O(n)复杂度内查找第K大数算法示例

    本文实例讲述了C++实现的O(n)复杂度内查找第K大数算法.分享给大家供大家参考,具体如下: 题目:是在一组数组(数组元素为整数,可正可负可为0)中查找乘积最大的三个数,最后输出最大乘积. 从题目我们知道只有两种结果存在: 1)三个最大的正整数相乘: 2)一个最大的正整数和两个最小的负数相乘. 所以我们需要找出数组中最大的三个数的乘积m,然后与数组中最小的两个数相乘再与最大的数相乘的结果n,然后比较m,n,选出最大的数即为最终的结果. 参考代码:http://www.jb51.net/artic

  • C++实现迷宫算法实例解析

    本文以实例形式描述了C++实现迷宫算法.本例中的迷宫是一个矩形区域,它有一个入口和一个出口.在迷宫的内部包含不能穿越的墙或障碍.障碍物沿着行和列放置,它们与迷宫的矩形边界平行.迷宫的入口在左上角,出口在右下角 本实例迷宫算法的功能主要有: 1.自动生成10*10迷宫图 2.判断是否有迷宫出口,并且画出路线图 具体实现代码如下: # include <iostream> # include <list> # include <sys/timeb.h> # include

  • C++实现的归并排序算法详解

    本文实例讲述了C++实现的归并排序算法.分享给大家供大家参考,具体如下: 归并排序 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法. 该算法是采用分治法(Divide and Conquer)的一个非常典型的应用.将已有序的子序列合并,得到完全有序的序列: 即先使每个子序列有序,再使子序列段间有序.若将两个有序表合并成一个有序表,称为二路归并. 归并过程 1.比较a[i]和a[j]的大小,若a[i]≤a[j],则将第一个有序表中的元素a[i]复制到temp[k]中,并令i

  • C++ 搬水果贪心算法实现代码

    C++ 搬水果贪心算法实现代码 (1)题目描述: 在一个果园里,小明已经将所有的水果打了下来,并按水果的不同种类分成了若干堆,小明决定把所有的水果合成一堆.每一次合并,小明可以把两堆水果合并到一起,消耗的体力等于两堆水果的重量之和.当然经过 n‐1 次合并之后,就变成一堆了.小明在合并水果时总共消耗的体力等于每次合并所耗体力之和. 假定每个水果重量都为 1,并且已知水果的种类数和每种水果的数目,你的任务是设计出合并的次序方案,使小明耗费的体力最少,并输出这个最小的体力耗费值.例如有 3 种水果,

  • C++二分查找(折半查找)算法实例详解

    本文实例讲述了C++二分查找(折半查找)算法.分享给大家供大家参考,具体如下: 二分查找又称折半查找,优点是比较次数少,查找速度快,平均性能好:其缺点是要求待查表为有序表,且插入删除困难. 因此,折半查找方法适用于不经常变动而查找频繁的有序列表. 二分查找思想 首先,假设表中元素是按升序排列,将表中间位置记录的关键字与查找关键字比较,如果两者相等,则查找成功: 否则利用中间位置记录将表分成前.后两个子表,如果中间位置记录的关键字大于查找关键字,则进一步查找前一子表,否则进一步查找后一子表. 重复

  • C++实现的大数相乘算法示例

    本文实例讲述了C++实现的大数相乘算法.分享给大家供大家参考,具体如下: 昨晚校招笔试,虐的没脸睡觉,能力太渣了,但我还在码农的坑里前行,希望早日跳坑,解决衣食住行之忧. 大数相乘,是指那些相乘结果或是乘数本身用long long类型都会溢出的数字,通常这些数字都通过string类型进行表示,借助于可动态调整大小的数据结构(vector,string,deque)模拟实现数字的乘法操作.对于普通的乘法,我们知道m位数和n位数相乘,最后的结果位数在区间内[m+n-1,m+n].例如34*56,我们

  • 基于C++的拼多多算法在线笔试题示例

    本文实例讲述了基于C++的拼多多算法在线笔试题.分享给大家供大家参考,具体如下: 最近在狼厂实习中,很久没做题了.秋招第一发, 拼多多...  四个简单题,看到有些人竟然觉得难? 我来降一发自己的RP,这题目觉得难的,如果你拿到比我好的Offer,我是不服气的.. 四个题...其实我也就写了40分钟吧..不过最后也没有满分, 390/400, 第三题不知道为嘛一直有10分过不了.. 更一下, 刚刚好像发现第三题...这个>号, 我写的是>= ....? 可是我看题目好像是 >= 呀...

  • 华为2019校招笔试题之处理字符串(python版)

    说明 华为2019在线笔试题,现整理如下,以供之后参考 GitHub 题目介绍 ################################################################# ################################################################# ''' 题目描述: -- 对输入字符串检查是否存在非法字符,输出合法字符串(去重)和非法字符串(不去重) -- 对合法字符串循环左移10次,在进行排序输出.

  • 基于JVM 中常见垃圾收集算法介绍

    JVM 中常见的垃圾收集算法有四种: 标记-清除算法(Mark-Sweep): 复制算法(Copying): 标记-整理(Mark-Compact): 分代收集: 下面我们来一一介绍: 一.标记-清除算法(Mark-Sweep) 这是最基础的垃圾收集算法,算法分为"标记"和"清除"两个阶段:首先标记出所有需要回收的对象,在标记完成后统一回收掉所有被标记的对象.它的主要缺点有两个:一个是效率问题,标记和清除效率都不高:另一个是空间问题,标记清除后会产生大量不连续的内存

  • 基于javascript实现获取最短路径算法代码实例

    这篇文章主要介绍了基于javascript实现获取最短路径算法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 //A算法 自动寻路 路径 class GetAutoPath{ constructor(id, map, sPos, ePos, mapArr){ //this.type = id.type; this.id = id; this.map = map; this.sPos = sPos; this.ePos = eP

  • Python OpenCV基于霍夫圈变换算法检测图像中的圆形

    目录 第一章:霍夫变换检测圆 ① 实例演示1 ② 实例演示2 ③ 霍夫变换函数解析 第二章:Python + opencv 完整检测代码 ① 源代码 ② 运行效果图 第一章:霍夫变换检测圆 ① 实例演示1 这个是设定半径范围 0-50 后的效果. ② 实例演示2 这个是设定半径范围 50-70 后的效果,因为原图稍微大一点,半径也大了一些. ③ 霍夫变换函数解析 cv.HoughCircles() 方法 参数分别为:image.method.dp.minDist.param1.param2.mi

  • C++基于栈的深搜算法实现马踏棋盘

    马踏棋盘(基于栈的深搜算法实现) 简单来说,从任意指定方格出发,为马寻找一条走遍棋盘每一格并且只经过一次的一条路径,这就是马踏棋盘的简单描述. 话不多说,代码如下,要是有什么不懂的地方,欢迎讨论~ #include <stdio.h> #include <stdlib.h> #define M 8 //行 #define N 8 //列   typedef struct snode    //坐标 {     int flag;     int x;     int y; }sta

  • 基于Matlab实现嗅觉优化算法的示例代码

    目录 1.概述 2.37 个 CEC 基准测试函数代码 3.F1 Matlab代码仿真 1.概述 嗅觉剂优化是一种新颖的优化算法,旨在模仿气味分子源尾随的药剂的智能行为.该概念分为三个阶段(嗅探,尾随和随机)是独特且易于实现的.此上传包含 SAO 在 37 个 CEC 基准测试函数上的实现. 2.37 个 CEC 基准测试函数代码 function [lb,ub,dim,fobj] = Select_Function(F) switch F case 'F1' %Admijan fobj = @

  • 基于Matlab实现野狗优化算法的示例代码

    目录 1.概述 2.捕食过程的数学模型 2.1 种群初始化 2.2 群体攻击过程 2.3 迫害攻击过程 2.4 野狗的存活率 3.Matlab代码实现 3.1 代码 3.2 结果 1.概述 野狗优化算法(Dingo Optimization Algorithm, DOA)模仿澳大利亚野狗的社交行为.DOA算法的灵感来源于野狗的狩猎策略,即迫害攻击.分组策略和食腐行为.为了提高该方法的整体效率和性能,在DOA中制定了三种与四条规则相关联的搜索策略,这些策略和规则在搜索空间的强化(开发)和多样化(探

  • Python实现基于标记的分水岭分割算法

    目录 1. 原理 2.代码实现 2.1 利用OpenCV和c++实现分水岭算法 2.2 Python实现分水岭分割(1) 2.3 Python实现分水岭分割(2) 分水岭技术是一种众所周知的分割算法,特别适用于提取图片中的相邻或重叠对象.使用分水岭方法时,我们必须从用户定义的标记开始.这些标记可以使用点击手动定义,也可以使用阈值或形态学处理方法定义. 分水岭技术将输入图像中的像素视为基于这些标记的局部极小值(称为地形)——该方法从标记向外“淹没”山谷,直到各种标记的山谷相遇.为了产生准确的分水岭

  • 基于Python实现从头搭建一个在线聊天室框架

    目录 整体技术栈 搭建权限框架 构建前端页面 今天从头开始做一个在线聊天网站,网上各种各样的聊天工具已经很多了,为啥还要做这么一个聊天工具呢,无他,兴趣耳! 今天先完成第一部分,搭建起聊天网站的整体框架. 整体技术栈 flask 框架 flask_login 的使用 jquery 简单应用 搭建权限框架 还是使用 Flask 来搭建后台应用,使用 flask-login 扩展来处理用户登陆鉴权逻辑. 首先定义登陆表单 class LoginForm(FlaskForm):     usernam

随机推荐