C语言基础练习——Day13

目录

选择题

编程题

统计每个月兔子的总数

数列的和


选择题

1、如果x=2014,下面函数的返回值是

cpp 复制代码
int fun(unsigned int x)
{
     int n = 0;
     while(x + 1)
     {
         n++;
         x = x | (x + 1);
     }
     return n;
}
  • A 20
  • B 21
  • C 23
  • D 25

答案:C
💡
解析:
上面的代码中的x = x | (x + 1)表示改变从右向左的第一个0为1,直到变成全1的时候x+1就溢出为全0,循环结束。2014的二进制是0000 0000 000 0000 0000 0111 1101 1110,所以结果是23

2、下列语句定义x为指向int类型变量a的指针,其中哪一个是正确的

  • A int a , *x = a;
  • B int a , *x = &a;
  • C int *x = &a , a;
  • D int a , x = a;

答案:B
💡
解析:
A选项的x是指针,赋值时使用a不合适,C选项在赋值时a变量还没定义,D选项中的x不是指针。

3、下面有关空指针和未初始化指针,说法错误的是

  • A 对0x0这个地址取值是非法的
  • B 空指针可以确保不指向任何对象或函数; 而未初始化指针则可能指向任何地方
  • C 空指针与任何对象或函数的指针值都不相等
  • D malloc在其内存分配失败时返回的是一个未初始化的指针

答案:D
💡
解析:
malloc在其内存分配失败时返回为NULL,而在内存分配成功时返回未初始化的指针

4、若有定义int a[8];,则以下表达式中不能代表数组元素a[1]的地址的是

  • A &a[0]+1
  • B &a[1]
  • C &a[0]++
  • D a+1

答案:C
💡
解析:
a[0]表示数组第一个元素,而a[0]++是一个表达式,不可以对表达式取地址

5、以下选项中,对基本类型相同的两个指针变量不能进行运算的运算符是

  • A +
  • B -
  • C =
  • D ==

答案:A
💡
解析:
A错误,因为两个地址相加无意义也可能越界,所以规定不允许指针相加。B选项,可以求出两个数据元素储存位置之间的相隔同数据类型的元素个数,C选项,赋值,没问题,D选项,判断两指针是否相同

编程题

统计每个月兔子的总数

题目链接:统计每个月兔子的总数_牛客题霸_牛客网 (nowcoder.com)

描述
有一种兔子,从出生后第3个月起每个月都生一只兔子,小兔子长到第三个月后每个月又生一只兔子。
例子:假设一只兔子第3个月出生,那么它第5个月开始会每个月生一只兔子。
一月的时候有一只兔子,假如兔子都不死,问第n个月的兔子总数为多少?
数据范围:输入满足1≤ n ≤31
输入描述:
输入一个int型整数表示第n个月
输出描述:
输出对应的兔子总数

思路解析:

通过对题目的分析可以发现本题和斐波那契数列的思路基本一致,所以可以直接使用斐波那契数列求解的思想

参考代码:

cpp 复制代码
#include <stdio.h>

int GetRabbits(int month){
    if(month == 1 || month == 2){
        return 1;
    }

    return GetRabbits(month-1)+GetRabbits(month -2);
}

int main() {
    int month = 0;
    scanf("%d", &month);
    int rabbits = GetRabbits(month);
    printf("%d ",rabbits);
    return 0;
}

数列的和

题目链接:数列的和_牛客题霸_牛客网 (nowcoder.com)

描述
数列的定义如下:数列的第一项为n,以后各项为前一项的平方根,求数列的前m项的和。
输入描述:
输入数据有多组,每组占一行,由两个整数n(n<10000)和m(m<1000)组成,n和m的含义如前所述。
输出描述:
对于每组输入数据,输出该数列的和,每个测试实例占一行,要求精度保留2位小数。

思路解析:

本题只需要处理好每次求和的数据,使用sqrt函数求平方根即可

参考代码:

cpp 复制代码
#include <math.h>
#include <stdio.h>

int main() {
    double n = 0;
    int m = 0;
    while (~scanf("%lf%d",&n,&m)) {
        double sum = 0;
        while (m--) {
            sum += n;
            n = sqrt(n);
        }
        printf("%.2f\n",sum);
    }
    return 0;
}
相关推荐
汪款学嵌入式2 分钟前
C语言常用字符串处理函数
c语言
左手の明天1 小时前
【C/C++】C++中使用vector存储并遍历数据
c语言·开发语言·c++
.晚街听风~1 小时前
【无标题】
c语言
_GR3 小时前
2013年蓝桥杯第四届C&C++大学B组真题及代码
c语言·数据结构·c++·算法·蓝桥杯
半桔4 小时前
二叉树(C语言)
c语言·开发语言·数据结构·算法·链表·github
马浩同学5 小时前
【ESP32】ESP-IDF开发 | WiFi开发 | TCP传输控制协议 + TCP服务器和客户端例程
c语言·网络·单片机·mcu·tcp/ip
Unique_yt5 小时前
1.25 实现一个终端的功能
c语言·开发语言·网络
『往事』&白驹过隙;5 小时前
操作系统(Linux Kernel 0.11&Linux Kernel 0.12)解读整理——内核初始化(main & init)之硬盘初始化
linux·c语言·数据结构·物联网·操作系统
菜还不练就废了15 小时前
蓝桥杯练习日常|c/c++竞赛常用库函数(下)
c语言·c++·蓝桥杯
嵌入式新人菜鸟16 小时前
单片机-STM32 WIFI模块--ESP8266 (十二)
c语言·stm32·单片机