C语言程序设计之基础易错题锦集5

2024-08-24 23:04

本文主要是介绍C语言程序设计之基础易错题锦集5,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

C语言程序设计之基础易错题锦集5

  • 问题 5_0
    • 解析 5_0
  • 问题 5_1
    • 解析 5_1
  • 问题 5_2
    • 解析 5_2
  • 问题 5_3
    • 结果 5_3
  • 问题 5_4
    • 结果 5_4
  • 问题 5_5
    • 结果 5_5

问题 5_0

         以下程序输出结果是?

	#include<stdio.h>main(){int i=1, j=2, k=3;if(i++==1&&(++j==3||k++==3))printf("%d,%d,%d\n", i, j, k);}

解析 5_0

         条件表达式 i++==1&&(++j==3||k++==3) 中的各个运算优先级顺序从高到低为 ++、==、&&、||,先求解 ++j==3 的值为真,且 j 的值为 3,由于是逻辑或运算,所以此时计算机不再进行 || 后面的运算,k 的值仍然是 3,该表达式变为 i++==1&&1=(1==1&&1)=(1&&1)=1,然后 i 为 2,所以输出结果为:233。

问题 5_1

        以下程序输出结果是?

	#include<stdio.h>void fun(int x){if(x/2>1) fun(x/2);printf("%d", x);}main(){fun(7);printf("\n");}

解析 5_1

         在函数 fun(int x)的递归调用中,当 x 除以 2 的值大于 1,就接着执行函数 fun(x/2) ,所以主函数中,当执行 fun(7) 时,函数 fun 共执行两次,第一次输出 3, 第二次输出 7。

问题 5_2

         以下程序输出的结果是?

	#include<stdio.h>#include<string.h>typedef struct{char name[9];char sex;float score[2]; }STU;void f(STU a){STU b = {"Zhao", 'm', 85.0, 90.0};int i;strcpy(a.name, b.name);a.sex = b.sex;for(i=0; i<2; i++)a.score[i] = b.score[i];}main(){STU c = {"Qian", 'f', 95.0, 92.0};f(c);printf("%s,%c,%2.0f,%2.0f\n",c.name, c.sex, c.score[0], c.score[1]);}

解析 5_2

         题目中把结构体变量作为一个整体传给相应的形参,传递的是实参结构体变量中的值。调用函数体内对形参结构体变量中任何成员的操作,都不会影响对应实参中成员的值。

问题 5_3

         函数 fun 的功能是:将字符串中的字符逆序输出,但不改变字符串的内容。

	#include<stdio.h>void fun(char *a){if(*a){fun(a+1);printf("%c", *a);}}main(){char s[10]="abcd";printf("处理前字符串 = %s\n处理后字符串 = ", s);fun(s);printf("\n");}

结果 5_3

Result_5_3

问题 5_4

         已给出结构体构成的链表结点 a、b、c,各个结点的数据域中均存入字符,函数 fun 的作用是:将 a、b、c 三个结点连成一个单向链表,并输出链表结点中的数据。

	#include<stdio.h>typedef struct list{char data;struct list *next;}Q;void fun(Q *pa, Q *pb, Q *pc){Q *p;pa->next = pb;pb->next = pc;p = pa;while(p){printf("%c", p->data);p = p->next;}printf("\n");}main(){Q a,b,c;a.data = 'E';b.data = 'F';c.data = 'G';c.next = NULL;fun(&a, &b, &c);}

结果 5_4

Result_5_4

问题 5_5

         请编写一个函数 float fun(double h),该函数的功能是:使变量 h 中的值保留两位小数,并对第三位进行四舍五入(规定 h 中的值为正数)。
         例如,若 h 值为 1234.567,则返回值为 1234.570000;若 h 值为 1234.564,则返回值为 1234.560000。

	#include<stdio.h>#include<conio.h>#include<stdlib.h>float fun(float h){long t;t = (h*1000+5)/10;return (float)t/100;}void main(){FILE *wf;float a;system("CLS");printf("Enter a: ");scanf("%f", &a);printf("The original data is: ");printf("%f\n\n", a);printf("The result : %f\n", fun(a));wf = fopen("out.dat", "w");printf(wf,"%f", fun(8.32566));fclose(wf);}

结果 5_5

Result_5_5

         逻辑上没有出问题,但是由于 编译器问题涉及精度问题,故而没能输出理论结果。

这篇关于C语言程序设计之基础易错题锦集5的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103853

相关文章

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念

AI基础 L9 Local Search II 局部搜索

Local Beam search 对于当前的所有k个状态,生成它们的所有可能后继状态。 检查生成的后继状态中是否有任何状态是解决方案。 如果所有后继状态都不是解决方案,则从所有后继状态中选择k个最佳状态。 当达到预设的迭代次数或满足某个终止条件时,算法停止。 — Choose k successors randomly, biased towards good ones — Close

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,