当前位置:网站首页>Written interview topic: looking for the lost pig
Written interview topic: looking for the lost pig
2020-11-08 10:30:00 【Oc ccy4urvn】
Original published in :

Today's National Day , The Mid Autumn Festival, too , It's really rare . stay 21 Century's 100 During the year , have only 4 Year is like this . At home today , With family , Cook and eat , Do housework , Read some idle books , By the way, write something , I'll go out later , And then come back and run .
The campus autumn recruitment has begun in succession , I wish the students in school get their favorite offer, I also wish the students who are recruited by the society to change jobs smoothly .
today , Let's see A An interview question for the company :
Yes n Pigs , Take the car to the vegetable market , The pigs were pasted with 1~n The number of , All of a sudden , A pig jumped out of the car and ran away , Ask for the number of the pig that escaped .

The pig is still very poor , Slip away , We also need to track down the numbers . below , Let's look at algorithms .
Algorithm 1: Making difference method
Ideas :
Step1: To calculate the 1~n And a.
Step2: Find the sum of the numbers of the remaining pigs b.
Step3: a-b That's the number of the pig .
The disadvantage of this algorithm is : seek 1~n And , It might spill over .
Algorithm 2: Tagging
Ideas : Open up an array m, use m[i]=0 or 1 To record i Whether there is , For lost pigs j, There must be m[j]=0.
The disadvantage of this algorithm is : The space complexity is O(n)
Algorithm 3: Sequencing
Ideas : Sort the rest of the pigs , The pig that is running away j At the number of , There must be a break , So they know j The specific value of .
The disadvantage of this algorithm is : Let's take the example of fast track , Neither time complexity nor space complexity is optimal .
Algorithm 4: Exclusive or law ( The best algorithm )
Ideas :
Step1: To calculate the 1~n Exclusive or values a.
Step2: Find the exclusive or value of the number of the remaining pigs b.
Step3: seek a and b Exclusive or values , It's the number of the pig that escaped j.
The principle is as follows :
hypothesis n=5, The number of the lost pig is 3, So the number of the remaining pigs is 2, 4, 1, 5, Let's calculate :
j = 1^2^3^4^5^2^4^1^5
obviously , According to the exchange law of XOR , The above operations can be simplified , as follows :
j = 1^1^2^2^4^4^5^5^3 = 3
This gives you the number of the pig that's gone . here , The time complexity is O(n), The space complexity is O(1), This is the best algorithm . As for the procedure , It's simple , So I won't go back to .
In the previous post , We can actually see , XOR is a special kind of “ Addition and subtraction ”, therefore , Algorithm 1 Sum algorithm 4 It's a wonderful thing to do the same . About binary XORs , You can refer to :
The circuit principle of computer addition and proteus Simulation
版权声明
本文为[Oc ccy4urvn]所创,转载请带上原文链接,感谢
边栏推荐
- Rust:命令行参数与环境变量操作
- If you don't understand the gap with others, you will never become an architect! What's the difference between a monthly salary of 15K and a monthly salary of 65K?
- 计算机网络基本概念(五)局域网基本原理
- 新的目标市场在哪里?锚定的产品是什么?| 十问2021中国企业服务
- Basic concepts of computer network (5) basic principles of local area network
- 抖音直播监控Api:随机推荐
- PDMS cutting software
- How does spotify drive data-driven decision making?
- Mate 40系列发布 搭载华为运动健康服务带来健康数字生活
- 双向LSTM在时间序列异常值检测的应用
猜你喜欢

Solve Safari browser download file name garbled problem

2020-11-05

Japan PSE certification

PCIe 枚举过程

Basic concepts of computer network (5) basic principles of local area network

M 端软件产品设计思虑札记 - 知乎

Oops, the system is under attack again

函数周期表丨筛选丨值丨SELECTEDVALUE - 知乎

为 Docsify 自动生成 RSS 订阅

Python learning Day1 -- Basic Learning
随机推荐
Web novice problem of attacking and defending the world
It's 20% faster than python. Are you excited?
An error occurred while starting the kernel was successfully resolved
print( 'Hello,NumPy!' )
413【毕设课设】基于51单片机无线zigbee无线智能家居光照温湿度传输监测系统
Japan PSE certification
Personal current technology stack
Cloud Alibabab笔记问世,全网详解仅此一份手慢无
laravel8更新之速率限制改进
数据科学面试应关注的6个要点
vivoY73s和vivoY70s的区别 vivoY73s和vivoY70s哪个值得入手
Python Gadgets: code conversion
仅用六种字符来完成Hello World,你能做到吗?
Automatically generate RSS feeds for docsify
IQKeyboardManager 源代码看看
运维人员常用到的 11 款服务器监控工具
渤海银行百万级罚单不断:李伏安却称治理完善,增速呈下滑趋势
next.js实现服务端缓存
i5 1135g7和i5 1035g1参数对比区别大吗? 哪个好
笔试面试题目:判断单链表是否有环