刚才去做了阿里巴巴的编程测验,好消息是抽到的题相对别的题简单一些,坏消息是编的太慢了,没有做完.

现在把题目和自己后来编出来的代码贴在这里,供大家参考.

题目:

1. 从命令行输入若干个正整数(大于等于2个),得到一个集合N。
2. 从N中任意取出两个数并求和,得到的值构成集合A。
3. 从N中任意取出两个数,并求差的绝对值,得到的值构成集合B。
4. 从集合A和集合B当中,任意取出两个数,其差的绝对值,又构成集合D
D的最小元素是d1,D的最大元素是d2,D的元素个数是s
请输出d1+d2+s

题目要求

编译器版本: gcc 4.8.4
请使用标准输入输出(stdin,stdout) ;请把所有程序写在一个文件里,勿使用已禁用图形、文件、网络、系统相关的头文件和操作,如sys/stat.h , unistd.h , curl/curl.h , process.h
时间限制: 3S (C/C++以外的语言为: 5 S) 内存限制: 128M (C/C++以外的语言为: 640 M)
输入:
n //这是输入整数的个数 x1 //第一个整数 x2 //第二个整数 ... xn //第n个整数
输出:
m //一个整数
输入范例:
5
101
102
103
104
105
输出范例:
417

题目中的代码:

 #include <iostream>
#include <vector>
#include <numeric>
#include <limits>
using namespace std;
// 请完成下面这个函数,实现题目要求的功能
// 当然,你也可以不按照这个模板来作答,完全按照自己的想法来 ^-^
int result(const vector <int>& inputs) {
return ;
} int main() {
int size = ;
cin >> size;
cin.ignore (numeric_limits<std::streamsize>::max(), '\n');
vector<int> points;
for(size_t i=; i<size; ++i) {
int item;
cin >> item;
cin.ignore (numeric_limits<std::streamsize>::max(), '\n');
points.push_back(item);
}
int res = result(points);
cout << res << endl;
return ;
}

自己编写的区域:

 //第一版 未使用set
int result(const vector <int>& inputs) {
vector<int> vecA;
for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
vecA.push_back(inputs[i] + inputs[j]);
for (int k = ; k < vecA.size() - ; ++k)
{
if ((inputs[i] + inputs[j]) == vecA[k])
{
vecA.pop_back();
}
}
}
} vector<int> vecB;
for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
vecB.push_back((abs)(inputs[i] - inputs[j]));
for (int k = ; k < vecB.size() - ; ++k)
{
if ((abs)(inputs[i] - inputs[j]) == vecB[k])
{
vecB.pop_back();
}
}
}
} vector<int> vecD;
for (int i = ; i < vecA.size(); ++i)
{
for (int j = ; j < vecB.size(); ++j)
{
vecD.push_back((abs)(vecA[i] - vecB[j]));
for (int k = ; k < vecD.size() - ; ++k)
{
if ((abs)(vecA[i] - vecB[j]) == vecD[k])
{
vecD.pop_back();
}
} }
} int nMax, nMin;
nMax = nMin = vecD[];
for (int k = ; k < vecD.size(); ++k)
{
if (vecD[k] >= nMax)
{
nMax = vecD[k];
}
if (vecD[k] <= nMin)
{
nMin = vecD[k];
}
}
return nMax + nMin + vecD.size();
} //第二版 使用vector较多
int result(const vector <int>& inputs) {
set<int> setA, setB, setD; vector<int> vecA;
for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
vecA.push_back(inputs[i] + inputs[j]);
}
}
setA.insert(vecA.begin(), vecA.end()); vector<int> vecB;
for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
vecB.push_back((abs)(inputs[i] - inputs[j]));
}
}
setB.insert(vecB.begin(), vecB.end()); vector<int> vecD;
for (int i = ; i < vecA.size(); ++i)
{
for (int j = ; j < vecB.size(); ++j)
{
vecD.push_back((abs)(vecA[i] - vecB[j]));
}
}
setD.insert(vecD.begin(), vecD.end());
vector<int> ivec(setD.begin(), setD.end()); //set没有sort函数,先加到vector中.
sort(ivec.begin(), ivec.end());
cout << ivec[] + ivec[ivec.size() - ] + ivec.size();
return ;
} //第三版 去除不必要的vector
int result(const vector <int>& inputs) {
set<int> setA, setB, setD; for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
setA.insert(inputs[i] + inputs[j]); //这里可以使用insert.
}
} for (int i = ; i < inputs.size() - ; ++i)
{
for (int j = i + ; j < inputs.size(); ++j)
{
setB.insert((abs)(inputs[i] - inputs[j]));
}
} for (set<int>::iterator it1 = setA.begin(); it1 != setA.end(); ++it1)
{
for (set<int>::iterator it2 = setB.begin(); it2 != setB.end(); ++it2)
{
setD.insert((abs)(*it1 - *it2));
}
}
vector<int> ivec(setD.begin(), setD.end()); //set没有sort函数,先加到vector中.
sort(ivec.begin(), ivec.end());
return ivec[] + ivec[ivec.size() - ] + ivec.size(); }

评论中学到的新知识

//From 木子可 
set<int> s, A, B, D;
for (auto i : inputs) //!C++11新特性
s.insert(i); //!for循环省略了{}
for (auto i = s.begin(); i != prev(s.end()); i++)//!prev,next新的特性吧
for (auto j = next(i); j != s.end(); j++)
{
A.insert(*i + *j);
} for (auto i = s.begin(); i != prev(s.end()); i++)
for (auto j = next(i); j != s.end(); j++)
{
int tmp = *i - *j;
tmp = tmp > ? tmp : -tmp;
B.insert(tmp);
}
//From Garcia-0 

forward iterator是前向迭代器,总共有5种:

     种类                                      特性                                                                   示例

输入迭代器                   读,不能写,只支持自增                                                istream_iterator

输出迭代器                   写,不能读,只支持自增               ostream_iterator

前向迭代器       读和写,只支持自增                 unordered_map、unordered_set

双向迭代器       读和写,支持自增和自减               map,set,list

随机访问迭代器            读和写,支持完整的迭代器算术运算                            string,vector,deque

阿里巴巴2018届应届生在线编程测验-研发工程师C/C++的更多相关文章

  1. JavaSE 基础知识(常识概念 + 基础语法)问答总结/面试题 —— 讲给应届生的 Java 开源知识项目

    写在最前面 这个项目是从20年末就立好的 flag,经过几年的学习,回过头再去看很多知识点又有新的理解.所以趁着找实习的准备,结合以前的学习储备,创建一个主要针对应届生和初学者的 Java 开源知识项 ...

  2. 2019应届生,用python爬虫记录自己求职经历,分享求职中的一些坑

    前言 文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. PS:如有需要Python学习资料的小伙伴可以加点击下方链接自行获取http ...

  3. Open XML SDK 在线编程黑客松

    2015年2月10日-3月20日,开源社 成员 微软开放技术,GitCafe,极客学院联合举办" Open XML SDK 在线编程黑客松 ",为专注于开发提高生产力的应用及服务的 ...

  4. GISer 应届生找工作历程(完结)

    有半个月没更博客了,前几天在学校准备这保研,因为没有时间复习高数自然就没有过.    也没啥的,我本来就不打算复习,就是看看运气咋样(哈哈).在昨天开始跑的招聘会,一天下来不同地方跑了三家挺累的,记录 ...

  5. [ios-必看] 国人当自强:两岸三地在线编程学习网站大搜罗 [转]

    http://blog.csdn.net/lyy_whg/article/details/17350923 说到国内的在线编程学习网站,很多人都是一脸茫然,即使是资深开发者也是如此.在许多人眼中,尽管 ...

  6. "双非"应届生校招如何获得大厂青睐?(内附技术岗超全求职攻略)

    写在前面的话 笔者从17年的2月份开始准备春招,其中遇到不少坑,也意识到自己走过的弯路.故写了这篇文章总结一番,本文适合主动学习的,对自己要学的课程不明确的,对面试有恐惧症的...等将来打算从事技术岗 ...

  7. 应届生offer指南

    通用技术 1.一般公司对应届生都要考察编程能力,所以应聘之前先刷刷题.我做面试官出的编程题两年没有变过.就是这道

  8. "双非"应届生校招如何获得大厂青睐?(内附前端大厂面经+技术岗超全求职攻略)

    写在前面的话 笔者从17年的2月份开始准备春招,其中遇到不少坑,也意识到自己走过的弯路.故写了这篇文章总结一番,本文适合主动学习的,对自己要学的课程不明确的,对面试有恐惧症的...等将来打算从事技术岗 ...

  9. 算法与数据结构(2)--英雄会第三届在线编程大赛:几个bing

    基础知识的回顾不再写到这里面了,会写一些算法算法的解答或者读一些相关书籍的笔记. 今天做了一道算法题,来自微软必应·英雄会第三届在线编程大赛:几个bing? 做出来了...但不知道为啥执行测试用例失败 ...

随机推荐

  1. python 基础篇 2

    三.对变量.对象与赋值的浅析 1.不记住就完蛋了 1.1 记住:一切数据都是对象 1.2 记住:一切变量都是对数据对象的一个引用 1.3 分析:python内部的引用计数 sys.getrefcoun ...

  2. python requests get/post

    基本Get请求: #-*- coding:utf-8 -*- import requests url = 'http://www.baidu.com' r = requests.get(url) pr ...

  3. IE低版本兼容的感悟

    2017-04-09 曾经折磨一代人的兼容问题,如今也在同样折磨着我们,明明可以做JS判断来避免对ie低版本的兼容,但是却还是耐心的做着兼容,你可能会问这是为什么, 我们调的不是兼容,是整整一代人的情 ...

  4. es6之各种数据类型的扩展

    一. 字符串的扩展 为字符串添加了Iterator,可以被for...of遍历 includes.startsWith.endsWith都会返回布尔值,且支持第二个参数(开始搜索的位置),endsWi ...

  5. AES加密解密算法---java

    package com.BFGJ.AES; import java.util.Random; import java.util.StringTokenizer; import javax.crypto ...

  6. 编写高质量代码改善程序的157个建议:使用Dynamic来简化反射的实现

    最近有时间看点书了,把157个建议在重新看一遍,代码都调试一遍.当我看到第15个建议的时候有些出入,就记录下来,欢迎大家来探讨. 第十五条建议是,使用dynamic简化反射的使用,没有说明具体的条件. ...

  7. JS读写浏览器cookie及读取页面参数

    JS读写浏览器cookie及读取页面参数 var zbrowser = { //设置浏览器cookie,exdays是cookie有效时间 setCookie: function (c_name, v ...

  8. 学容器必须懂 bridge 网络 - 每天5分钟玩转 Docker 容器技术(32)

    上一节我们讨论了 none 和 host 类型的容器网络,本节学习应用最广泛也是默认的 bridge 网络. Docker 安装时会创建一个 命名为 docker0 的 linux bridge.如果 ...

  9. 把angular项目整合到.net mvc中

    之前的开发选择的是完全舍弃服务端,仅保留最简单web服务器提供angular经打包的静态资源,此外所有的业务与数据请求都访问一个分离的WebApi来实现.不过最近碰到一个需求,有必要使用多个客户端,而 ...

  10. javascript中apply,call,bind区别,bind兼容等问题总结

    1 三者的相似之处: (1).都是用来改变函数的this对象的指向的 (2).都是用第一个参数来做this对象的指向 (3).都可以传参数进去 那么,具体到它们有什么区别呢?请看下面的例子: 两个对象 ...