从零开始的LC刷题(34)*: Single Number

原题:

Given a non-empty array of integers, every element appears twice except for one. Find that single one.

Note:

Your algorithm should have a linear runtime complexity. Could you implement it without using extra memory?

Example 1:

Input: [2,2,1]
Output: 1

Example 2:

Input: [4,1,2,1,2]
Output: 4

题意是找到只有一个的数字,先想到暴力解法O(n^2):

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int find=0;
        for(vector<int>::iterator it=nums.begin();it<nums.end();it++){
            cout<<*it;
            for(vector<int>::iterator is=nums.begin();is<nums.end();is++){
                if(*it==*is){find++;}
            }
            if(find==2){cout<<*it<<endl;find=0;}
            else return *it;
        }
        return INT_MAX;
    }
};

不出意外超时了,然后想到设置指示容器,处理一个数时,在容器中找到相同数的话pop,没有时push,因为还是属于O(n^2)结果并不够好:

Success

Runtime: 220 ms, faster than 5.41% of C++ online submissions for Single Number.

Memory Usage: 10 MB, less than 21.90% of C++ online submissions for Single Number.

代码:

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        vector<int> findelem;
        for(vector<int>::iterator it=nums.begin();it<nums.end();it++){
            vector<int>::iterator f=find(findelem.begin(),findelem.end(),*it);
            if(f==findelem.end()){findelem.push_back(*it);continue;}
            else findelem.erase(f);
        }
        return findelem[0];
    }
};

然后想到用哈希表来减少查找次数,结果:

Success

Runtime: 112 ms, faster than 5.41% of C++ online submissions for Single Number.

Memory Usage: 10.6 MB, less than 21.50% of C++ online submissions for Single Number.

可以看到效果不是特别好,代码:

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        vector<int> findelem;
        int hash[99999]={};
        for(vector<int>::iterator it=nums.begin();it<nums.end();it++){
            if (hash[abs(*it)%99999]>0){
                vector<int>::iterator f=find(findelem.begin(),findelem.end(),*it);
                if(f==findelem.end()){findelem.push_back(*it);hash[abs(*it)%99999]++;continue;}
                else {findelem.erase(f);hash[abs(*it)%99999]--;}
            }
            else {findelem.push_back(*it);hash[abs(*it)%99999]++;}}
        return findelem[0];
    }
};

然后就想不到办法了,看了一下解法,还有两种,一种是数学法,c++下不好使因为没有python中的set函数对应功能的函数,还有一个就比较有意思了,用到了按位异或运算,原理是a⊕b⊕a=(a⊕a)⊕b=0⊕b=b,结果:

Success

Runtime: 12 ms, faster than 97.96% of C++ online submissions for Single Number.

Memory Usage: 9.7 MB, less than 58.27% of C++ online submissions for Single Number.

代码:

class Solution {
public:
    int singleNumber(vector<int>& nums) {
        int result=0;
        for(vector<int>::iterator it=nums.begin();it<nums.end();it++){
            result^=*it;
            }
        return result;
    }
};

 

# 高校智慧校园解决方案摘要 智慧校园解决方案是针对高校信息化建设的核心工程,旨在通过物联网技术实现数字化校园的智能化升级。该方案通过融合计算机技术、网络通信技术、数据库技术和IC卡识别技术,初步实现了校园一卡通系统,进而通过人脸识别技术实现了更精准的校园安全管理、生活管理、教务管理和资源管理。 方案包括多个管理系统:智慧校园管理平台、一卡通卡务管理系统、一卡通人脸库管理平台、智能人脸识别消费管理系统、疫情防控管理系统、人脸识别无感识别管理系统、会议签到管理系统、人脸识别通道管理系统和图书馆对接管理系统。这些系统共同构成了智慧校园的信息化基础,通过统一数据库和操作平台,实现了数据共享和信息一致性。 智能人脸识别消费管理系统通过人脸识别终端,在无需接触的情况下快速完成消费支付过程,提升了校园服务效率。疫情防控管理系统利用热成像测温技术、视频智能分析等手段,实现了对校园人员体温监测和疫情信息实时上报,提高了校园公共卫生事件的预防和控制能力。 会议签到管理系统和人脸识别通道管理系统均基于人脸识别技术,实现了会议的快速签到和图书馆等场所的高效通行管理。与图书馆对接管理系统实现了一卡通系统与图书馆管理系统的无缝集成,提升了图书借阅的便捷性。 总体而言,该智慧校园解决方案通过集成的信息化管理系统,提升了校园管理的智能化水平,优化了校园生活体验,增强了校园安全,并提高了教学和科研的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值