splunk公司的一道笔试题
题目要求:
一个游泳馆里有很多储物柜,每个储物柜都有一个ID号,但是老板不喜欢4这个数字,所以ID号里都不能有4,ID号从1开始编号,让你设计所有储物柜的ID号,用程序输出,比如
输入 4
输出 5
输入 5
输出 6
输入 14
输出 16
如果题目看不懂,看下这张数据对应表:
输入:1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
输出:1 2 3 5 6 7 8 9 10 11 12 13 15 16 17
也就是根据输入的序号,求出实际的序号,实际的序号是去除掉含有4的数字
类似很多大厂的题目,初看简单,几乎每个人多少都能写点,但仔细一想,要写出高效、简洁的代码并不简单。按照常规思路,实现如下(效率较低)
1 #include "stdafx.h"
2 #include <iostream>
3 using namespace std;
4
5 bool include4(int n)
6 {
7 while (n)
8 {
9 if ((n%10) == 4)
10 return true;
11 n /=10;
12 }
13
14 return false;
15 }
16
17 int GetNumber(int n)
18 {
19 if (n < 0)
20 return 0;
21
22 int pos = 0;
23
24 while (n--)
25 while (include4(++pos));
26
27 return pos;
28 }
29
30 int _tmain(int argc, _TCHAR* argv[])
31 {
32 for (int i = 0; i < 100; ++i)
33 {
34 cout << i << ":" << GetNumber(i) << endl;
35 }
36 return 0;
37 }
转换下思路,考虑去掉4,等效于从10个数里拿走一个数,剩余9个数,所以新的数据模式可认为是9进1。
十进制情况下,我们要想表达一个数,m = n*10 + a; //n为除数; a为余数,取值范围为(0~9)
同理,“9进制”情况下m = n*9 + a; //n为除数;a为余数,取值范围为(0,1,2,3,5,6,7,8,9)
代码如下:
1 int GetNumber(int n)
2 {
3 if (n < 0)
4 {
5 return 0;
6 }
7
8 int symbols[] = { 0, 1, 2, 3, 5, 6, 7, 8, 9 };
9 int count = sizeof(symbols)/sizeof(symbols[0]);
10 return n <= count ? symbols[n] : GetNumber(n / count) * 10 + GetNumber(n % count);
11 }
splunk公司的一道笔试题的更多相关文章
- Java中有关构造函数的一道笔试题解析
Java中有关构造函数的一道笔试题解析 1.详细题目例如以下 下列说法正确的有() A. class中的constructor不可省略 B. constructor必须与class同名,但方法不能与c ...
- 一道笔试题来理顺Java中的值传递和引用传递
题目如下: private static void change(StringBuffer str11, StringBuffer str12) { str12 = str11; str11 = ...
- 某公司的U3D笔试题
某公司的U3D笔试题 今天这套笔试题感觉做得一般. 随后是二对一的技术面试,但涉及的技术细节相对较少,更多的是对以前工作.项目经历的询问. 然后说今天先到这里,让我等通知. 我还特意问了一下,通知 ...
- 一道笔试题和UML思想 ~
一句软件工程界的名言,让我想起了一个和一道笔试题有关的故事.希望更多的人了解 UML 背后的思想比他的语法更重要,是笔者写作本文的一点小愿望. 一.从一句软件工程名言说起 对很多事情的处理上,东西方都 ...
- 所在实习公司的JS笔试题
在班上无聊的时候看到了一份JS笔试题(我是电面进去的,没做过这份题~~),开始还觉得蛮简单......后来觉得还是很有意思的,贴出来一起看看. 题目一: if(!("a" in w ...
- 由阿里巴巴一道笔试题看Java静态代码块、静态函数、动态代码块、构造函数等的执行顺序
一.阿里巴巴笔试题: public class Test { public static int k = 0; public static Test t1 = new Test("t1&qu ...
- 转:一道笔试题-将int型数组强制转换为char*,再求strlen,涉及大小端
写出如下程序运行结果: #include<stdio.h> #include<string.h> int main() { int a[2000]; char *p = (ch ...
- golang 中 string 转换 []byte 的一道笔试题
背景 去面试的时候遇到一道和 string 相关的题目,记录一下用到的知识点.题目如下: s:="123" ps:=&s b:=[]byte(s) pb:=&b s ...
- 通过一道笔试题浅谈javascript中的promise对象
因为前几天做了一个promise对象捕获错误的面试题目,所以这几天又重温了一下promise对象.现在借这道题来分享下一些很基础的知识点. 下面是一个面试题目,三个promise对象捕获错误的例子,返 ...
随机推荐
- python编程中的并发------多进程multiprocessing
任务例子:喝水.吃饭动作需要耗时1S 单任务:(耗时20s) for i in range(10): print('a正在喝水') time.sleep(1) print('a正在吃饭') time. ...
- Lua语言15分钟快速入门
转载自: https://blog.csdn.net/qq_15437667/article/details/75042526 -- 单行注释 --[[ [多行注释] --]] ---------- ...
- 牛客网PAT练兵场-在霍格沃茨找零钱
题目地址:https://www.nowcoder.com/pat/6/problem/4063 题意:按照题目的进制计算即可 /** * *作者:Ycute *时间:2019-11-14-21.45 ...
- 牛客网PAT练习场-个位数的统计
思路:每接受一个字符,便统计一次即可 题目地址:https://www.nowcoder.com/questionTerminal/a2063993dd424f9cba8246a3cf8ef445 # ...
- Flink-1.10中的StreamingFileSink相关特性
一切新知识的学习,都离不开官网得相关阅读,那么StreamingFileSink的官网介绍呢? https://ci.apache.org/projects/flink/flink-docs-rele ...
- 阿里巴巴Java开发手册1.4.0
链接:https://pan.baidu.com/s/16kKzcRcu20SMDdydMm9ZUw 提取码:p9ef
- Java高级特性——反射机制(第二篇)
在Java高级特性——反射机制(第一篇)中,写了很多反射的实例,可能对于Class的了解还是有点迷糊,那么我们试着从内存角度去分析一下. Java内存 从上图可以看出,Java将内存分为堆.栈.方法区 ...
- c#值类型引用类型第一章
概要 本篇文章主要简单扼要的讲述值类型和引用类型更进阶的理解和使用.如果希望更多的了解和技术讨论请记得看文章末尾,望各位看官多多支持多多关注,关注和支持是我更新文章的最大动力.在这里谢谢大家.温馨提示 ...
- AQI分析
A Q I 分 析 1.背景信息 AOI( Air Quality Index),指空气质量指数,用来衡量空气清洁或污染的程度.值越小,表示空气质量越好.近年来,因为环境问题,空气质量也越来越受到人 ...
- Android开发之Toast吐司的一个封装好的工具类。带有源代码java文件,
import android.content.Context; import android.widget.Toast; //Toast统一管理类 public class T { private T ...