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

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



选择题:

题一:

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 解决无法得到不确定的一个数字

#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节点值输出即最小值。

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];
}

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

                                             

目录
相关文章
|
2月前
|
存储 编译器 C语言
【C语言】数据类型全解析:编程效率提升的秘诀
在C语言中,合理选择和使用数据类型是编程的关键。通过深入理解基本数据类型和派生数据类型,掌握类型限定符和扩展技巧,可以编写出高效、稳定、可维护的代码。无论是在普通应用还是嵌入式系统中,数据类型的合理使用都能显著提升程序的性能和可靠性。
78 8
|
3月前
|
C语言 开发者
C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧
本文深入探讨了C语言中的模块化编程思想,介绍了模块化编程的概念、实现方式及其优势,强调了合理划分模块、明确接口、保持独立性和内聚性的实践技巧,并通过案例分析展示了其应用,展望了未来的发展趋势,旨在帮助读者提升程序质量和开发效率。
99 5
|
3月前
|
C语言
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性
C语言编程中,错误处理至关重要,能提升程序的健壮性和可靠性。本文探讨了C语言中的错误类型(如语法错误、运行时错误)、基本处理方法(如返回值、全局变量、自定义异常处理)、常见策略(如检查返回值、设置标志位、记录错误信息)及错误处理函数(如perror、strerror)。强调了不忽略错误、保持处理一致性及避免过度处理的重要性,并通过文件操作和网络编程实例展示了错误处理的应用。
101 4
|
4月前
|
NoSQL C语言 索引
十二个C语言新手编程时常犯的错误及解决方式
C语言初学者常遇错误包括语法错误、未初始化变量、数组越界、指针错误、函数声明与定义不匹配、忘记包含头文件、格式化字符串错误、忘记返回值、内存泄漏、逻辑错误、字符串未正确终止及递归无退出条件。解决方法涉及仔细检查代码、初始化变量、确保索引有效、正确使用指针与格式化字符串、包含必要头文件、使用调试工具跟踪逻辑、避免内存泄漏及确保递归有基准情况。利用调试器、编写注释及查阅资料也有助于提高编程效率。避免这些错误可使代码更稳定、高效。
788 12
|
5月前
|
消息中间件 Unix Linux
C语言 多进程编程(五)消息队列
本文介绍了Linux系统中多进程通信之消息队列的使用方法。首先通过`ftok()`函数生成消息队列的唯一ID,然后使用`msgget()`创建消息队列,并通过`msgctl()`进行操作,如删除队列。接着,通过`msgsnd()`函数发送消息到消息队列,使用`msgrcv()`函数从队列中接收消息。文章提供了详细的函数原型、参数说明及示例代码,帮助读者理解和应用消息队列进行进程间通信。
|
5月前
|
缓存 Linux C语言
C语言 多进程编程(六)共享内存
本文介绍了Linux系统下的多进程通信机制——共享内存的使用方法。首先详细讲解了如何通过`shmget()`函数创建共享内存,并提供了示例代码。接着介绍了如何利用`shmctl()`函数删除共享内存。随后,文章解释了共享内存映射的概念及其实现方法,包括使用`shmat()`函数进行映射以及使用`shmdt()`函数解除映射,并给出了相应的示例代码。最后,展示了如何在共享内存中读写数据的具体操作流程。
|
5月前
|
Linux C语言
C语言 多进程编程(七)信号量
本文档详细介绍了进程间通信中的信号量机制。首先解释了资源竞争、临界资源和临界区的概念,并重点阐述了信号量如何解决这些问题。信号量作为一种协调共享资源访问的机制,包括互斥和同步两方面。文档还详细描述了无名信号量的初始化、等待、释放及销毁等操作,并提供了相应的 C 语言示例代码。此外,还介绍了如何创建信号量集合、初始化信号量以及信号量的操作方法。最后,通过实际示例展示了信号量在进程互斥和同步中的应用,包括如何使用信号量避免资源竞争,并实现了父子进程间的同步输出。附带的 `sem.h` 和 `sem.c` 文件提供了信号量操作的具体实现。
|
1月前
|
存储 算法 C语言
【C语言程序设计——函数】素数判定(头歌实践教学平台习题)【合集】
本内容介绍了编写一个判断素数的子函数的任务,涵盖循环控制与跳转语句、算术运算符(%)、以及素数的概念。任务要求在主函数中输入整数并输出是否为素数的信息。相关知识包括 `for` 和 `while` 循环、`break` 和 `continue` 语句、取余运算符 `%` 的使用及素数定义、分布规律和应用场景。编程要求根据提示补充代码,测试说明提供了输入输出示例,最后给出通关代码和测试结果。 任务核心:编写判断素数的子函数并在主函数中调用,涉及循环结构和条件判断。
63 23
|
1月前
|
算法 C语言
【C语言程序设计——函数】利用函数求解最大公约数和最小公倍数(头歌实践教学平台习题)【合集】
本文档介绍了如何编写两个子函数,分别求任意两个整数的最大公约数和最小公倍数。内容涵盖循环控制与跳转语句的使用、最大公约数的求法(包括辗转相除法和更相减损术),以及基于最大公约数求最小公倍数的方法。通过示例代码和测试说明,帮助读者理解和实现相关算法。最终提供了完整的通关代码及测试结果,确保编程任务的成功完成。
68 15
|
1月前
|
C语言
【C语言程序设计——函数】亲密数判定(头歌实践教学平台习题)【合集】
本文介绍了通过编程实现打印3000以内的全部亲密数的任务。主要内容包括: 1. **任务描述**:实现函数打印3000以内的全部亲密数。 2. **相关知识**: - 循环控制和跳转语句(for、while循环,break、continue语句)的使用。 - 亲密数的概念及历史背景。 - 判断亲密数的方法:计算数A的因子和存于B,再计算B的因子和存于sum,最后比较sum与A是否相等。 3. **编程要求**:根据提示在指定区域内补充代码。 4. **测试说明**:平台对代码进行测试,预期输出如220和284是一组亲密数。 5. **通关代码**:提供了完整的C语言代码实现
61 24

热门文章

最新文章