C语言面试题每日一练(一)[通俗易懂]

C语言面试题每日一练(一)[通俗易懂]C语言作为嵌入式Linux开发的必备工具,作为嵌入式Linux开发的基础语言,那么在面试嵌入式工程师时C语言定是面试中的重中之重。作为一名开学就大三的老学长,不得不为找工作做必要准备。每天做一道C语言面试题,并且能够融会贯通。2020.8.5题目描述:    在未排序的数组中找到第k个最大元素。请注意,你需要找的是数组排序后的第k个最大的元素而不是第k个不同的元素。示例1:输入:32.

大家好,又见面了,我是你们的朋友全栈君。

       C语言作为嵌入式Linux开发的必备工具,作为嵌入式Linux开发的基础语言,那么在面试嵌入式工程师时C语言定是面试中的重中之重 。作为一名开学就大三的老学长,不得不为找工作做必要准备。每天做一道C语言面试题,并且能够融会贯通。
Alt

2020.8.5

题目描述:
       在未排序的数组中找到第k个最大元素。请注意,你需要找的是数组排序后的第k个最大的元素而不是第k个不同的元素。

示例 1:
输入:3 2 1 5 6 4和 k=2
输出:5

示例 2:
输入3 2 3 1 2 4 5 5 6和 k=4
输出:4

题目分析:
       这道题主要考察的是排序的相关知识,通过给一个数组进行排序然后再找出第k大的元素并返回就可以了。
解题代码:

#include <stdio.h>
void swap(int *a,int *b)
{ 
   
    int temp;
    temp=*a;
    *a=*b;
    *b=temp;
}
int find_kth_largest(int *nums,int numsize,int k){ 
   
    //冒泡排序
    int i,j;
    for(i=0;i<numsize;i++)
    { 
   
        for(j=i+1;j<numsize;j++)
        { 
   
            if(nums[i]<nums[j])
                swap(&nums[i],&nums[j]);
            
        }
    }
    return nums[k-1];
}
int main(int argc,const char *argv[])
{ 
   
    int arr[10]={ 
   1,3,6,5,4,8,9,3,0,2};
    int tmp;
    tmp=find_kth_largest(arr,10,3);
    printf("%d\n",tmp);
    for(int i=0;i<10;i++)//排序结果输出,看排序是否正确
        printf("%d ",arr[i]);
    return 0;
}

2020.8.6

题目描述
       以下程序的输出结果是什么?

#include<stdio.h>

#define max(a,b) ((a)>(b)?(a):(b))

int main(void)
{ 
   
	int x[5]={ 
   0,2,1,3,-1};
	int biggest=x[0];
	int i=1;
	while(i<5)
	{ 
   
		biggest=max(biggest,x[i++];	
	}
	printf("%d\n",biggest);
}

题目分析:
       本题主要考察了宏定义、三目运算符、变量自增相关知识。

       #define 是用来定义宏的,在编译的时候,编译器会把代码中 max(a,b)都替换成 (a>b?a:b)。三目运算符 ( (exp1) ? exp2 : exp3 ) 的意思是,如果dao 表达式exp1的值为真,则返回表达式exp2,否则返回表达式exp3。所以 (a>b?a:b) 的意思是 如果a的值大于b,就返回a的值,否则返回b的值。

第一步:
biggest=x[0]
biggest=(x[0]>x[i++]?x[0]:x[i++]) //i++是先赋值后运算
              值为x[1]    值为x[2]
                i=2        i=3
biggest=(x[0]>x[1]?x[0]:x[2]//0>2?0:1
此时biggest的返回值为x[2],既为1

第二步:
biggest=x[2]
biggest=(x[2]>x[i++]?x[2]:x[i++])
             值为x[3]    值为x[4]
               i=4        i=5
biggest=(x[2]>x[3]?x[2]:x[4]//1>3?1:-1
此时biggest的返回值为x[4],即为-1

题目结果:

输出结果为:  -1

2020.8.7

题目描述

       有定义:typedef int (* p)(char,int); 请描述这个语句含义

题目解析

       声明一个函数指针类型的新名字为p,要求此类型满足指向函数返回值为int,形参为两个,分别是char和int。在此处函数的名字并不需要固定,所以不需要声明在类型里typedef原类型 新类型的名字

2020.8.8

题目描述:

       【面试题-是陷阱么?】32位系统中,下面代码,请说出*ptr1,*ptr2的值。

int a[4] = { 
   x, y, z, m};

int *ptr1 = *(a + 1);

int *ptr2 = (int *) ((int)a + 1);

题目解析:

       本题需要注意给指针赋值的方式,在定义时给其赋值,定义以后赋值的方式,以及数组名代表首元素的地址。同时,还要注意打印的是对应指指针变量的值还是地址。

赋值方式1int a[4] = { 
   1, 2, 3, 4};
	int *ptr1=a;//ptr1指向a[0]
赋值方式2int *ptr1;
	ptr1=a;
赋值方式3:
	int *ptr1=&a[0];	

注意:当在指针变量赋值为数字,会默认将数字认定为地址,那么该指针就是指向该地址。

#include<stdio.h>
int main()
{ 
   
	int *ptr=64;
	printf("ptr:%x\n",ptr);//打印ptr指向的地址
}

       运行程序发现打印的结果是:ptr:64

       通过在编译器下运行以下代码:

#include<stdio.h>
int main()
{ 
   
    int a[4]={ 
   1,2,3,4};
    int *ptr1=*(a+1);
    int *ptr2=((int)a+1);
    printf("ptr1 = %x\n",ptr1);
    printf("ptr2=%x\n",ptr2);
    printf("a+0=%x a+1=%x ",a+0,a+1);
}

输出结果为:

ptr1 = 2
ptr2=61ff09
a+0=61ff08 a+1=61ff0c

       可以明显的看出打印的结果为ptr1和ptr2对应指向的地址。int *ptr1=*(a+1);是将*(a+1)指向的值(2)当做地址赋值给ptr1,故打印的值为2。int *ptr2 = (int *) ((int)a + 1);是将数组元素的第一个地址(a[0]的地址)强制转换为整形然后加一赋值给ptr2。因此打印的值比a[0]的地址大一。

2020.8.9

题目描述:
       头文件中的ifndef/define/endif干什么用的?
题目解析:
       在c语言中,对同一个变量或者函数进行多次声明是不会报错的。所以如果h文件里只是进行了声明工作,即使不使用# ifndef宏定义,多个c文件包含同一个h文件也不会报错。同时可以防止头文件重复调用、部分语法重复声明定义。

2020.8.10

题目描述:

#include <stdio.h>
int fun( int x )
{ 
    
    int p;
    if (x == 0|| x == 1 ) 
        return(3);
    p = x - fun( x – 2 );
    return(p);main()
{ 
   
    printf ("%d\n",fun(9));
}

       程序运行后输出结果是?

题目解析:
       本题考察的函数的递归调用,func(9) = 9 – func(7), func(7) = 7 – func(5),func(5) = 5 – func(3),func(3) = 3 -func(1),又因为func(1) = 3, 所以 func(3) = 0, func(5) = 5 ,func(7) = 2 ,func(9) = 7

       不积小流无以成江河,不积跬步无以至千里。而我想要成为万里羊,就必须坚持学习来获取更多知识,用知识来改变命运,用博客见证成长,用行动证明我在努力。
       如果我的博客对你有帮助、如果你喜欢我的博客内容,记得“点赞” “评论” “收藏”一键三连哦!听说点赞的人运气不会太差,每一天都会元气满满呦!如果实在要白嫖的话,那祝你开心每一天,欢迎常来我博客看看。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/159282.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • 首个可用于深度学习的ToF相关数据集!基于置信度的立体相机以及ToF相机深度图融合框架…

    首个可用于深度学习的ToF相关数据集!基于置信度的立体相机以及ToF相机深度图融合框架…点击上方“计算机视觉工坊”,选择“星标”干货第一时间送达作者|cocoon编辑|3D视觉开发者社区目录✦contents1.概述2.方法以及网络结构2.1使用网络学习置信度2.1.1训练细节2.2双目以及ToF视差的fusion3.合成数据4.实验结果4.1测试集场景4.2置信度估计结果4.3视差估计定性以及定量结果5.参考文献附录:数据…

  • CHECK约束_数据库check约束怎么写

    CHECK约束_数据库check约束怎么写CHECK约束会检查输入到记录中的值是否满足一个条件,如果不满足这个条件则对数据库做的修改不会成功。比如,一个人的年龄是不可能为负数的,一个人的入学日期不可能早于出生日期,出厂月份不可能大于12。可以

  • Java内存管理-初始JVM和JVM启动流程(二)

    勿在流沙住高台,出来混迟早要还的。做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!上一篇分享了什么是程序,以及Java程序运行的三个阶段。也顺便提到了Java中比较重要的一个东西就是JVM(JAVA 虚拟机),那么今天在先了解一下JVM和JVM的启动流程。 知识地图:1、什么是虚拟机虚拟机(Virtual Machine)指通过软件模拟的具有完整硬件系…

  • 浅谈Mock测试

    浅谈Mock测试一、Mock测试的定义 Mock就是在测试过程中,对于一些不容易构造/获取的对象,创建一个Mock对象来模拟对象的行为 二、Mock测试的作用 1、为什么要做Mock: 在对代码进行单元测试过程中,经常会有以下的情况发生: classA依赖classB和classC classD依赖classC和classE classB依赖…..

  • Senparc.Weixin.MP SDK 微信公众平台开发教程(三):微信公众平台开发验证

    Senparc.Weixin.MP SDK 微信公众平台开发教程(三):微信公众平台开发验证要对接微信公众平台的”开发模式”,即对接到自己的网站程序,必须在注册成功之后(见Senparc.Weixin.MPSDK微信公众平台开发教程(一):微信公众平台注册),等待官方审核,审核通过之后,会在后台顶部出现“高级功能”菜单。使用“高级功能”>“开发模式”之前,必须有一个已经部署在Internet上,可以用80端口访问的网站(域名或IP访问都可以),一些…

  • setfacl解释「建议收藏」

    setfacl解释「建议收藏」setfacl:设置文件访问控制列表,针对单独文件,设置单独用户权限用法:setfacl-参数用户权限文件参数:-m,–modify=acl更改文件的访问控制列表-M,–modify-file=file从文件读取访问控制列表条目更改-x,–remove=acl根据文件中访问控制列表移除条目-X,–remove-file=file从文件读取访问控制列表条目…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号