面试题目2--实现Printf

本文详细介绍了如何使用va_list、va_start等宏来自定义实现printf函数,以支持可变参数列表。此外,还探讨了一千万个数据的重复项删除及找出长度最长的100条数据的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.实现printf
解决方法
利用stdarg宏来解决可变参数问题
头文件:<stdarg.h>
va_list;
type va_arg( va_list arg_ptr, type );
void va_end( va_list arg_ptr );
void va_start( va_list arg_ptr, prev_param ); (ANSI version)
在VC6.0下,我们转到定义出,可以清晰发现这些宏的定义:

分析
va_list 是用宏定义的标识符,是指向字符类型的指针
va_start(ap,v) 取出va_list 定义的变量的地址,并加上可变元素的数目
va_arg(ap,t) 每次取指针指向的内容,并在宏的内部将指针后移
va_end(ap) 将原指针指向空,以防止野指针的出现

#include<stdio.h>
#include<stdarg.h>
int my_printf(char* str,...)
{
    va_list arg;//定义char* 变量 arg
    int count = 0;
    char* str_tmp = NULL;
    va_start(arg,str);//为arg进行初始化
    while(*str != '\0')
    {   
        switch(*str)
        {
            case 'c':
                putchar(va_arg(arg,int));//取下一个参数的字符,并打印
                count++;
                break;
            case 's':   
                str_tmp = (char*)va_arg(arg,int);//取下一个参数的地址,因为这个是字符串
                while(*str_tmp != '\0')//利用解引用进行输出
                {       
                    putchar(*str_tmp);
                    count++;
                    str_tmp++;  
                }
                break;
            default:
                putchar(*str);  //不为'c'或's',那么直接将它打印
                count++;
                break;  
        }
        str++;      
    }
    va_end(arg);//将arg指向空,防止野指针
    return count;
}
int main()
{   
    my_printf("s ccc","hello",'H','h','s');
    return 0;
}

2.海量数据处理:
一千万个数据删除重复项;
找出长度最长的100条;

3.成员函数如何调用

4.守护进程拉起另外一个进程

### IT领域常见面试题目汇总 在IT领域,常见的面试题目涵盖了技术能力、逻辑思维、问题解决能力以及团队合作等多个方面。以下是一些典型的IT面试题目及其相关背景: 1. **编程语言基础** 编程语言的基础知识是面试中的重点内容之一。例如C/C++、Java、Python等语言的特性、语法细节和常见陷阱。 - 举例:解释C语言中的指针与数组的区别[^1]。 - 示例代码: ```c int main() { int arr[5] = {1, 2, 3, 4, 5}; int *ptr = arr; printf("Array value: %d\n", arr[0]); // 使用数组索引访问 printf("Pointer value: %d\n", *ptr); // 使用指针解引用访问 return 0; } ``` 2. **算法与数据结构** 算法和数据结构是评估候选人解决问题能力的重要部分。常见的问题包括排序算法、查找算法、树、图等的应用。 - 举例:实现快速排序算法并分析其时间复杂度[^1]。 - 示例代码: ```python def quick_sort(arr): if len(arr) <= 1: return arr else: pivot = arr[len(arr) // 2] left = [x for x in arr if x < pivot] middle = [x for x in arr if x == pivot] right = [x for x in arr if x > pivot] return quick_sort(left) + middle + quick_sort(right) ``` 3. **系统设计** 系统设计题考察候选人对大规模系统架构的理解能力。例如,如何设计一个高可用的分布式系统或缓存系统。 - 举例:设计一个支持百万级并发用户的聊天应用[^1]。 4. **数据库相关** 数据库相关的题目通常涉及SQL查询优化、索引设计、事务处理等内容。 - 举例:编写一个SQL查询,找出销售额最高的前10个产品[^1]。 - 示例代码: ```sql SELECT product_name, SUM(sales_amount) AS total_sales FROM sales GROUP BY product_name ORDER BY total_sales DESC LIMIT 10; ``` 5. **操作系统与网络** 操作系统和网络方面的知识也是面试中的重要部分,尤其是对于后端开发工程师而言。 - 举例:解释TCP三次握手的过程及其作用。 6. **行为面试题** 行为面试题主要考察候选人的职业素养和沟通能力。例如离职原因、团队协作经验等。 - 举例:描述一次你如何解决团队冲突的经历[^2]。 7. **需求分析与设计方法** 对于软件工程师来说,理解用户需求并进行合理的需求分析是非常重要的技能。 - 举例:什么是软件需求分析?常见的需求分析方法有哪些[^3]? --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值