文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

C语言:选择+编程(每日一练)

2023-08-31 05:46

关注

目录

选择题:

题一:

题二:

题三:

题四:

题五:

编程题:

题一:自除数

思路一:

题二:除自身以外数组的乘积

思路二:

本人实力有限可能对一些地方解释和理解的不够清晰,可以自己尝试读代码,或者评论区指出错误,望海涵!

感谢大佬们的一键三连! 感谢大佬们的一键三连! 感谢大佬们的一键三连!


题一:

1、下列程序的输出是( )
#include
int main()
{
        int a [12]= {1,2,3,4,5,6,7,8,9,10,11,12},*p[4],i;
        for(i=0;i<4;i++)
        p[i]=&a [i*3];
        printf("%d\n",p[3][2]);
        return 0;
}

A: 上述程序有错误    B:  C: 8    D: 12

答案解析:

        p是一个指针数组,p[i] = &a[i*3]相当于是把数组a每3个一组分开并把每组的首地址存在p数组,此时p类似一个4行3列的二维数组,p[3][2]就是4行第3个元素12。

题二:

2、二维数组X按行顺序存储,其中每个元素占1个存储单元。若 X[4][4] 的存储地址为 Oxf8b82140 , X[9][9] 的存储地址为 Oxf8b8221c ,则 X[7][7] 的存储地址为( )

A: Oxf8b821c4       B: Oxf8b821a6

C: Oxf8b82198       D: Oxf8b821c0

答案解析:

        假设每行有n个元素:那x[9][9]元素的地址 - x[4][4]元素的地址 = 0x21c0x140=5n+5(21c和140是地址末三位的十六进制数),这里n是43,假设x[7][7]的地址是z,x[7][7]元素的地址 - x[4][4]元素的地址 = z-0x140 = 3n+3,z = 3n+3+140 =3*43+3+0x140 = 0x84+0x140 = 0x1c4,看地址的尾数,选择A。

题三:

3、以下哪个选项可以正确描述 sizeof(double) ( )

A: 一个整型表达式              B: 一个双精度型表达式

C: 一个不合法的表达式       D: 一种函数调用

答案解析:

        sizeof是C语言中的一个操作符,不是函数调用,简单的说其作用就是返回一个对象或者类型所占的内存字节数,结果是无符号整数,因此可以把它看作是整型表达式。所以选择A。

题四:

4、下列代码运行后的结果是什么( )
int main()
{
        char a = 'a',b;
        printf("%c,", ++a);
        printf("%c\n", b = a++);
        return 0;
}

A: b,b    B: b,c    C: a,b    D: a,c

答案解析:

        变量a里边存的是字符'a',第一次输出先加加再输出,输出的是'b';第二次输出的时候,a先赋值再加加,赋值给b的就是a原来的值,输出b的时候的还是‘b’。

题五:

5、以下逗号表达式的值为( )
(x= 4 * 5 , x * 5) , x + 5;

A: 25     B: 20    C: 100    D: 45

答案解析:

        逗号表达式是从前到后依次计算子表达式,而其结果是最后一项的值,此题去掉括号后的表达式,和原表达式是等价的,先计算4*5并赋值给x,x变为20,中间x*5并没有改变x的值,最后一项x+5值是25,也就是整个表达式的值。

题一:自除数

728. 自除数 - 力扣(LeetCode)

示例 1:

输入:left = 1, right = 22输出:[1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22]

思路一:

        第一步:returnSize的初始值设为“0”,开辟足够容纳所有可能值的数组num

        第二步:将题目所给的值域遍历一遍,每次用“n”记录当前遍历值

        第三步:在确保每次都将一个数遍历完,当n=“0”,就循环结束,否则开始判断是不是自除数,分别拿到个位、十位、百位的数值并取余

        第四步:如果最后n的值为“0”,说明是自除数放入数组中,否则,不是。

int* selfDividingNumbers(int left, int right, int* returnSize){    int i = 0;    *returnSize = 0;    //开辟数组空间    int* num = (int*)malloc(4000);    //遍历数组所给元素范围    for(i = left; i <= right;i++)    {        int n = i;        //确保每次都将一个数遍历完        for(int j = 0;j < 4;j++)        {            //n为0,就不执行            if(n % 10 != 0)            {                int k = n % 10;                //判断是不是自除数                if(i % k == 0)                {                    n = n / 10;                }            }        }        //最后遍历完的就是自除数        if(n == 0)        {            num[(*returnSize)++] = i;        }    }    return num;}

题二:除自身以外数组的乘积

238. 除自身以外数组的乘积 - 力扣(LeetCode)

示例 1:

输入: nums = [1,2,3,4]输出: [24,12,8,6]

思路二:

需要明确知道: 题目意思是数组下标位置定义的值为除了自身以外数组里的所有元素相乘的值!

        第一步:分别定义两个足够大小的数组前缀arr1(当前数之前所有元素的乘积),后缀arr2(当前数之后所有元素的乘积),开辟相同大小的数组tmp;

        第二步:前缀:前缀数组第一个元素为“1”即arr1[i] = left;,然后乘以原数组的第“i”位,得到的值放到left中;

        第三步:从后往前,后缀:后缀数组最后一个元素为“1”即arr2[i] = right;然后乘以原数组的第“i”位,得到的值放到right中;

        第四步:前缀与后缀的各个对应的元素相乘就是除自身以外的所有元素相乘。

//题目意思是数组下标位置定义的值为除了自身以外数组里的所有元素相乘的值int* productExceptSelf(int* nums, int numsSize, int* returnSize){    int n = numsSize;    int arr1[100000] = {0};    int arr2[100000] = {0};    //开辟空间    int* tmp = (int*)malloc(sizeof(int)*n);    *returnSize = n;    int left = 1;    int right = 1;    int i = 0;    //计算各个元素的前缀    for(i = 0;i < n;i++)    {        arr1[i] = left;        left = arr1[i] * nums[i];    }    //计算各个元素的后缀    for(i = n-1;i >= 0;i--)    {        arr2[i] = right;        right = right * nums[i];    }    //前缀乘以后缀即结果    for(i = 0;i < n;i++)    {        tmp[i] = arr1[i] * arr2[i];    }    return tmp;}

                                              

来源地址:https://blog.csdn.net/weixin_71964780/article/details/132508565

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯