几个面试会让你实现的函数

1. atoi

需要考虑以下特殊情况:

  • 1.空字符串或者字符串长度为空
  • 2.错误输出标示(用一个全局变量实现)
  • 3.加号和减号
  • 4.其他非法字符
  • 5.溢出
#include <iostream>
#include <vector>
#include <stack>
#include <queue>
#include <sstream>
#include <math.h>

using namespace std;

class Solution {

private:
    
    enum Status{valid = 0, invalid = 1};
    Status g_status = invalid;
    
public:
    
    long long core(const char* cstr, int minus) {
        long long num = 0;
        
        while (*cstr != '\0') {
            if (*cstr <= '9' && *cstr >= '0') {
                num = num * 10 + minus * (*cstr - '0');
                if ((minus > 0 && num > 0x7FFFFFFF) || (minus < 0 && num < (signed int)0x80000000)) {
                    num = 0;
                    return num;
                }
                
                cstr++;
            }
            else {
                num = 0;
                return num;
            }
        }
        
        g_status = valid;
        return num;
    }
    
    int StrToInt(string str) {
        g_status = invalid;
        long long num = 0;
        
        const char* cstr = str.c_str();
        
        if(cstr != NULL && *cstr != '\0') {
            // 1. get minus
            int minus = 1;
            if(*cstr == '+')
                cstr++;
            else if (*cstr == '-') {
                minus = -1;
                cstr++;
            }
            
            // get num
            if (*cstr != '\0')
                num = core(cstr, minus);
        }
        
        return (int)num;
    }
    
};

2. strcpy

需要注意的地方:

  • 1.参数源字符串加const
  • 2.对源地址和目的地址加非0断言
  • 3.为了实现链式操作,将目的地址返回
char * strcpy( char *strDest, const char *strSrc )
    {
        assert( (strDest != NULL) && (strSrc != NULL) );
        char *address = strDest;
        while( (*strDest++ = * strSrc++) != '\0' );
        return address; 
    }

// 或者下面这种实现也行
char* strcpy1(char *strDest, const char* strSrc)
{
       assert(strSrc != NULL );
       assert(strDest != NULL);
       int i;
       char *address = strDest;
 
    for(i = 0; strSrc[i] != '\0'; i++)
              strDest[i] = strSrc[i];
       strDest[i] = '\0';
 
       return address;
}

3. strlen

size_t  strlen (const char * str)
{
        const char *eos = str;
        while( *eos++ ) ;
        return( eos - str - 1 );
}

4. strstr

在str1里寻找是否有str2子串,若有,则返回str2在str1里的第一个指针,若没有,则返回NULL

#include <iostream>
#include <cassert>
using namespace std;


const char* StrStr(const char* str, const char* sub_str) {
    assert(str != NULL && sub_str != NULL);
    
    for (int i = 0; str[i] != '\0'; i++) {
        int tmp = i;
        int j = 0;
        while (str[i++] == sub_str[j++]) {
            if(sub_str[j] == '\0')
                return &str[tmp];
        }
        i = tmp;
    }
    
    return NULL;
}

int main()
{
    const char *str1 = "wangyang";
    const char *str2 = "ang";
    const char *res = StrStr(str1, str2);
    
    if(res != NULL)
            cout<<res<<endl;
    else
        cout<<"NOT"<<endl;
        
    system("pause");
            
}

5. Memcpy

不用考虑内存重叠

void* memcpy(void* dst, const void* src, size_t size) {
        assert(dst != NULL && src != NULL);
        
        char *dst_tmp = (char*)dst;
        char *src_temp = (char*)src;
        
        while(size--) {
            *dst_tmp = *src_temp;
            dst_tmp++;
            src_temp++;
        }
        
        return dst;
    }

6. Memmove

需要考虑内存重叠, 但两种重叠只需考虑一种

void* memmove(void* dst, const void* src, size_t size) {
        assert(dst != NULL && src != NULL);
        
        char *dst_tmp = (char*)dst;
        char *src_tmp = (char*)src;
        
        if(src_tmp < dst_tmp && dst_tmp < src_tmp + size) {
            dst_tmp = dst_tmp + size - 1;
            src_tmp = src_tmp + size - 1;
            
            while (size -- ) {
                *dst_tmp = *src_tmp;
                dst_tmp--;
                src_tmp--;
            }
        }
        else {
            while(size--) {
                *dst_tmp = *src_tmp;
                dst_tmp++;
                src_tmp++;
            }
        }
        
        return dst;
    }

7. 判断链表是否有环

class Solution {
public:
    bool hasCycle(ListNode *head) {
        ListNode* p1 = head;
        ListNode* p2 = head;
        
        while (p2 && p2->next)
        {
            p1 = p1->next;
            p2 = p2->next->next;
            
            if (p1 == p2)
                return true;
        }
        
        return false;
    }
};

8. 快速排序

class Solution {
public:
    void quickSort(vector<int>& arr, int left, int right) {
        if(left < right) {
            int mid = partition(arr, left, right);
            quickSort(arr, left, mid - 1);
            quickSort(arr, mid + 1, right);
        }
    }
    
private:
    int partition(vector<int>& arr, int left, int right) {
        int l = left;
        int r = right;
        
        int length = right - left + 1;
        int randIndex = left + (rand() % length);
        swap(arr[randIndex], arr[left]);
        
        
        int target = arr[l];
        
        while(l < r) {
            while(l < r && arr[r] >= target) {
                r--;
            }
            
            if(l < r){
                arr[l] = arr[r];
                l++; 
            }
            
            while(l < r && arr[l] <= target) {
                l++;
            }
            
            if(l < r) {
                arr[r] = arr[l];
                r--;
            }
        }
        
        arr[l] = target;
        
        return l;
    }
};

9. 单例模式

class Singleton {
private:
    Singleton(){};
    static const Singleton* m_instance;
public:
    static const Singleton* getInstance() {
        return m_instance;
    }
       
};

const Singleton* Singleton::m_instance = new Singleton;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 196,200评论 5 462
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,526评论 2 373
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 143,321评论 0 325
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,601评论 1 267
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,446评论 5 358
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,345评论 1 273
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,753评论 3 387
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,405评论 0 255
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,712评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,743评论 2 314
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,529评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,369评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,770评论 3 300
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,026评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,301评论 1 251
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,732评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,927评论 2 336

推荐阅读更多精彩内容

  • 一、字符串操作 strcpy(p, p1) 复制字符串 strncpy(p, p1, n) 复制指定长度字符串 s...
    JaiUnChat阅读 1,650评论 0 7
  • 一、(一共三十题) 1.main() { int a[5]={1,2,3,4,5}; int *ptr=(int ...
    iOS_Alex阅读 926评论 0 0
  • 本文转自:http://www.cnblogs.com/lidabo/p/5225868.html 1)字符串操作...
    XiaohuiLI阅读 9,463评论 0 0
  • 史上最全的iOS面试题及答案 iOS面试小贴士———————————————回答好下面的足够了----------...
    Style_伟阅读 2,341评论 0 35
  • 1.什么是懒加载? 懒加载也就是延迟加载。当访问一个页面的时候,先把img元素或是其他元素的背景图片路径替换成一张...
    徐国军_plus阅读 302评论 0 8