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

目录

选择题:

题一:

题二:

题三:

题四:

题五:

编程题:

题一:记负均正

思路一:

题二:旋转数组的最小数字

思路一:


选择题:

题一:

1、已知函数的原型是: int fun(char b[10], int *a); ,设定义: char c[10];int d; ,正确的调用语句是( )

A: fun(c,&d); B: fun(c,d); C: fun(&c,&d); D: fun(&c,d);

题二:

2、请问下列表达式哪些会被编译器禁止多选 】( )
int a = 248, b = 4;
int const *c = 21;
const int *d = &a;
int *const e = &b;
int const * const f = &a;
A: *c = 32; B: *d = 43 C: e=&a D: f=0x321f

题三:

3、以下程序的输出结果 为( )
#include <stdio.h>
int i;
void prt()
{
for (i = 5; i < 8; i++)
printf("%c", '*');
printf("\t");
}

int main()
{
for (i = 5; i <= 8; i++)
prt();
return 0;
}
A: *** B: *** *** *** *** C: *** *** D: * * *

题四:

4、下面代码段的输出是( )

#include <stdio.h>

int i;

void prt()

{

for (i = 5; i < 8; i++)

printf("%c", '*');

printf("\t");

}

int main()

{

for (i = 5; i <= 8; i++)

prt();

return 0;

}

A: -6 B: 12 C: 0 D: -12

题五:

5、下列不能实现死循环的是()

A:while(1){} B:for(;1;){}

C:do{}while(1); D:for(;0;){}

编程题:

题一:记负均正

记负均正_牛客题霸_牛客网 (nowcoder.com)

示例1

输入:

复制代码
11 
1 2 3 4 5 6 7 8 9 0 -1

输出:

复制代码
1 5.0

思路一:

**本题主要难点在于:**nan(ind)-----得到不确定的一个数字;其余的就是输入,判断,记录。

num/counint > 0 ?num / counint:0 解决无法得到不确定的一个数字

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

int main() 
{
    int n = 0;
    int arr[2000] = {0};
    while (scanf("%d", &n) != EOF) 
    {
        int i = 0;
        int count = 0;
        int counint = 0;
        float num = 0;
        //循环判断是否正负
        for (i = 0; i < n; i++) 
        {
            scanf("%d", arr + i);
            if (arr[i] < 0) {
                count++;
            }
            if (arr[i] > 0) {
                num += arr[i];
                counint++;
            }
        }
        //nan(ind)
        //num/counint > 0 ?num / counint:0  解决无法得到不确定的一个数字
        printf("%d %0.1f", count, num/counint > 0 ?num / counint:0);
    }
    return 0;
}

题二:旋转数组的最小数字

旋转数组的最小数字_牛客题霸_牛客网 (nowcoder.com)

示例1

输入:

复制代码
[3,4,5,1,2]

返回值:

复制代码
1

思路一:

left记录开头,right记录结尾,mid记录中间节点情况一: 右边大于中间,说明最小值在左边;右边小于中间,说明最小值在右边;情况二: 考虑有相同的数,此时结尾-1。最后将left节点值输出即最小值。

cpp 复制代码
int minNumberInRotateArray(int* nums, int numsLen ) 
{
    //防止nums为NULL
    if(nums == NULL)
    {
        return 0;
    }
    int left = 0;
    int right = numsLen -1;
    //二分查找思路
    while(left < right)
    {
        int mid = (left + right)/2;
        //如果右边大于中间,最小值在左边
        if(nums[mid] < nums[right])
        {
            right = mid;
        }
        //如果右边小于中间,最小值在右边
        else if(nums[mid] > nums[right])
        {
            left = mid+1;
        }
        //如果右边等于中间,退一个单位
        else 
        {
            right = right-1;
        }
    }
    return nums[left];
}

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

相关推荐
songyuc几秒前
【BiFormer】BiFormer: Vision Transformer with Bi-Level Routing Attention 译读笔记
笔记·transformer
Once_day12 分钟前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
User_芊芊君子13 分钟前
【分布式训练】CANN SHMEM跨设备内存通信库:构建高效多机多卡训练的关键组件
分布式·深度学习·神经网络·wpf
Trouvaille ~22 分钟前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
聆风吟º22 分钟前
CANN算子开发:ops-nn神经网络算子库的技术解析与实战应用
人工智能·深度学习·神经网络·cann
觉醒大王24 分钟前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
偷吃的耗子27 分钟前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
笔画人生30 分钟前
# 探索 CANN 生态:深入解析 `ops-transformer` 项目
人工智能·深度学习·transformer
喜欢喝果茶.31 分钟前
QOverload<参数列表>::of(&函数名)信号槽
开发语言·qt
亓才孓32 分钟前
[Class类的应用]反射的理解
开发语言·python