博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
腾讯2019实习面试题
阅读量:4334 次
发布时间:2019-06-07

本文共 1057 字,大约阅读时间需要 3 分钟。

1. 题目一:数列极差问题

小Q的好朋友牛牛在纸上写了长度为n的正整数数列。牛牛要求小Q每次从数列中选取两个数a,b,把这两个数从数列中移除出去,然后在数列中加入a * b + 1,直到只剩一个数为止。小Q发现根据操作顺序的不同,最后得到的数的大小也不一样。小Q现在想让你帮他计算,在所有情况中能获得的最大值减去能获得的最小值等于多少?

输入:

3
1
2
3
输出:
2

解题方法:

第一步:先要对你输入的一个数组进行排序

第二步:擦掉最大的两个数,然后插入a*b+1 继续擦掉最大的两个数,最终得到最大值。

第三步:擦掉最大的两个数,然后插入a*b+1继续擦掉最小的两个数,最终得到最小值。

1 #include
2 #include
3 #include
4 using namespace std; 5 6 int main(){ 7 int n; 8 int num[1000]; 9 while(scanf("%d", &n) != EOF){10 for(int i=0; i

2. 题目二:自增数组

小Q发现了一种特殊的数组,叫做自增数组。这个数组支持一种操作:每次操作可以把数组中一个数自增1。现在有一个长度为n的自增数组,小Q现在想利用这个操作把数组中的每个数都变得不一样,请问你最少需要多少次操作?

#include 
#include
#include
using namespace std;int main() { int n = 0; vector
array; cin>>n; int t; for(int i=0 ;i
>t; array.push_back(t); } vector
cf; sort(array.begin(), array.end()); for(int i=1; i
arr(len,0); for(int i=0; i

 

转载于:https://www.cnblogs.com/sclczk/p/10960368.html

你可能感兴趣的文章
ffmpeg格式转换命令
查看>>
万方数据知识平台 TFHpple +Xpath解析
查看>>
Hive实现oracle的Minus函数
查看>>
秒杀多线程第四篇 一个经典的多线程同步问题
查看>>
RocketMQ配置
查看>>
vs code调试console程序报错--preLaunchTask“build”
查看>>
蚂蚁金服井贤栋:用技术联手金融机构,形成服务小微的生态合力
查看>>
端口号大全
查看>>
机器学习基石笔记2——在何时可以使用机器学习(2)
查看>>
POJ 3740 Easy Finding (DLX模板)
查看>>
MySQL 处理重复数据
查看>>
关于typedef的用法总结(转)
查看>>
【strtok()】——分割字符串
查看>>
Linux下安装rabbitmq
查看>>
曹德旺
查看>>
【转】判断点在多边形内(matlab)
查看>>
java基础之集合:List Set Map的概述以及使用场景
查看>>
Python 线程 进程 协程
查看>>
iOS语言中的KVO机制
查看>>
excel第一次打开报错 向程序发送命令时出错 多种解决办法含终极解决方法
查看>>