[经典面试题][暴风影音]暴风影音2014校招笔试题

简介:
  1. 合并两个已经排序的单链表为一个排序的单链表,相同内容只保留一个如:单链表a:1->2->3->4 单链表b:3->4->5 输出:1->2->3->4->5

    具体参考:[LeetCode]21.Merge Two Sorted Lists

    /*---------------------------------------------
    *   日期:2015-02-23
    *   作者:SJF0115
    *   题目: 合并排序链表
    *   来源:暴风影音
    *   博客:
    -----------------------------------------------*/
    #include <iostream>
    #include <climits>
    using namespace std;

    struct ListNode{
        int val;
        ListNode *next;
        ListNode(int x):val(x),next(NULL){}
    };
    //
    ListNode* MergeSortedList(ListNode *list1,ListNode *list2){
        // 头节点
        ListNode *head = new ListNode(-1);
        ListNode *p = head;
        int val1,val2;
        // 合并
        while(list1 != NULL || list2 != NULL){
            val1 = (list1 == NULL) ? INT_MAX : list1->val;
            val2 = (list2 == NULL) ? INT_MAX : list2->val;
            // 相同内容只保留一个
            if(val1 == val2){
                p->next = list1;
                list1 = list1->next;
                list2 = list2->next;
            }//if
            // 当前链表1else if(val1 < val2){
                p->next = list1;
                list1 = list1->next;
            }
            // 当前链表2else{
                p->next = list2;
                list2 = list2->next;
            }
            p = p->next;
        }//while
        return head->next;
    }

    int main() {
        int A[] = {1,2,4,7,9};
        int B[] = {1,3,4,8,9,11,12};
        // 链表1
        ListNode *head1 = new ListNode(A[0]);
        ListNode *p1 = head1;
        for(int i = 1;i < 5;i++){
            ListNode *node = new ListNode(A[i]);
            p1->next = node;
            p1 = node;
        }//for
        // 链表2
        ListNode *head2 = new ListNode(B[0]);
        ListNode *p2 = head2;
        for(int i = 1;i < 7;i++){
            ListNode *node = new ListNode(B[i]);
            p2->next = node;
            p2 = node;
        }//for
        ListNode *head = MergeSortedList(head1,head2);
        // 输出
        ListNode *p = head;
        while(p){
            cout<<p->val<<" ";
            p = p->next;
        }//while
        cout<<endl;
    }

2.编写程序,在原字符串中把尾部m个字符移动到字符串的头部,要求:长度为n字符串操作时间复杂度为O(n),时间复杂度为O(1)。
如:原字符串为”Ilovebaofeng”,m=7,输出结果:”baofengIlove”。

待续。。。。

3.暴风影音的片源服务器上保存着两个文件a和b,各存放50亿条URL,每条URL占用64字节,内存限制是4G,让你找出a,b文件共同的URL。要求:算法设计。

待续。。。。
目录
相关文章
|
8月前
|
编译器 程序员 C语言
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题(下)
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题
54 0
|
8月前
|
编译器 C语言 C++
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题(中)
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题
58 0
|
8月前
|
存储 程序员 编译器
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题(上)
从C语言到C++⑨(第三章_C&C++内存管理)详解new和delete+面试题笔试题
49 0
|
存储 数据采集 移动开发
经典的前端 面试笔试题(一)
经典的前端 面试笔试题
190 0
|
8月前
|
前端开发 小程序 JavaScript
2022前端面试笔试题及答案
2022前端面试笔试题及答案
199 0
sizeof运算与strlen函数的面试笔试题(排版很舒服)
sizeof运算与strlen函数的面试笔试题(排版很舒服)
|
存储 算法 网络协议
面试宝典之阿里巴巴校园招聘笔试题
面试宝典之阿里巴巴校园招聘笔试题
198 0
|
存储 算法 网络协议
面试宝典之阿里巴巴校园招聘笔试题
面试宝典之阿里巴巴校园招聘笔试题
105 0
|
SQL 人工智能 运维
运维面试,遇到的SQL笔试题
运维面试,遇到的SQL笔试题
186 2
|
存储 Web App开发 缓存
经典的前端 面试笔试题(二)
经典的前端 面试笔试题
177 0

热门文章

最新文章