成信大2021自动化专业-平时自主学习-C语言改错题解题参考-整理第08页

本文主要是介绍成信大2021自动化专业-平时自主学习-C语言改错题解题参考-整理第08页,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 第08页
    • 题面如下:
    • 题解如下:
      • D1054.c
      • D1055.c
      • D1056.c
      • D1057.c
      • D1058.c
      • D1059.c
      • D1060.c
      • D1061.c
      • D1062.c
      • D1063.c

第08页

题面如下:

在这里插入图片描述

题解如下:

D1054.c

原文件

#include <stdio.h>int main(void)
{ unsigned long int number, num1, num2, mask;int i;char str[33];printf("Please input num1 and num2 : ");scanf("%lu %lu", &num1, &num2);/*********Found************/mask = __________________;number = num1 ^ num2;for(i=0; i<32; i++){ /*********Found************/str[i] = __________________;mask >>= 1;}str[32] = '\0';printf("%lu ^ %lu = %s\n", num1, num2, str);return 0;
}	

改后文件

#include <stdio.h>int main(void)
{ unsigned long int number, num1, num2, mask;int i;char str[33];printf("Please input num1 and num2 : ");scanf("%lu %lu", &num1, &num2);/*********Found************/mask = 1<<31;number = num1 ^ num2;for(i=0; i<32; i++){ /*********Found************/str[i] = number&mask ?'1':'0';mask >>= 1;}str[32] = '\0';printf("%lu ^ %lu = %s\n", num1, num2, str);return 0;
}	

考查要点:

  1. 位运算,移位,要注意编译器给出的相应的数据类型的内存长度
  2. 从高位到低位,依次用与的方式取出该位上的1或是0,然后存入数组中
  3. 最后将字符数组做成字符串,即补结束符号

D1055.c

原文件

#include<stdio.h>  
#include<malloc.h>  #define N 13  
#define LEN sizeof(struct person)  int main(void)
{  int i, count;struct person{int number;/*********Found************/___________________________;} *head, *p1, *p2;head = p2 = NULL;for (i=1; i<=N; i++){  p1 = (struct person *)malloc(LEN);p1->number = i;if (NULL == head){/*********Found************/___________________________;}else{p2->next = p1; }p2 = p1;}p2->next = head;printf("the sequence out of the circle is:\n");for (count=1; count<N; count++){i = 1;while (i != 3){p1 = head;/*********Found************/___________________________;i++;}p2 = head;printf("%3d ", p2->number);p1->next = head = p2->next;/*********Found************/___________________________;}printf("\nThe betrayer of them is:%3d\n", head->number);return 0;
} 

改后文件

#include<stdio.h>  
#include<malloc.h>  #define N 13  
#define LEN sizeof(struct person)  int main(void)
{  int i, count;struct person{int number;/*********Found************/struct person * next;} *head, *p1, *p2;head = p2 = NULL;for (i=1; i<=N; i++){  p1 = (struct person *)malloc(LEN);p1->number = i;if (NULL == head){/*********Found************/head = p1;}else{p2->next = p1; }p2 = p1;}p2->next = head;printf("the sequence out of the circle is:\n");for (count=1; count<N; count++){i = 1;while (i != 3){p1 = head;/*********Found************/head = head->next;i++;}p2 = head;printf("%3d ", p2->number);p1->next = head = p2->next;/*********Found************/free(p2);}printf("\nThe betrayer of them is:%3d\n", head->number);return 0;
} 

考查要点:

  1. 约瑟夫环问题
  2. 节点定义中,需要有指针域
  3. 首节点,用头指针来指
  4. 用head指针后移的方式完成出圈
  5. 出圈后,要记得归还内存

D1056.c

原文件

#include <stdio.h>
#include <stdlib.h>
#include <string.h>int main(int argc, char *argv[])
{FILE *fp;char str[100], substr[100];int count = 0;if (argc != 2){printf("error");exit(0);}/*********Found************/fp = fopen(__________, "r");if (NULL == fp){printf("file open error\n");         exit(0);}printf("Please input the string : ");gets(substr);while (!feof(fp)){count++;str[0] = '\0';/*********Found************/___________________________;if (strstr(str, substr)){printf("Line%d : ", count);puts(str);}}/*********Found************/___________________________;return 0;
}

改后文件

#include <stdio.h>
#include <stdlib.h>
#include <string.h>int main(int argc, char *argv[])
{FILE *fp;char str[100], substr[100];int count = 0;if (argc != 2){printf("error");exit(0);}/*********Found************/fp = fopen(argv[1], "r");if (NULL == fp){printf("file open error\n");         exit(0);}printf("Please input the string : ");gets(substr);while (!feof(fp)){count++;str[0] = '\0';/*********Found************/fgets(str,100,fp);if (strstr(str, substr)){printf("Line%d : ", count);puts(str);}}/*********Found************/fclose(fp);return 0;
}

考查要点:

  1. 文件打开后要记得关闭
  2. fgets的三个参数要清楚:写内存缓区冲指针,大小,文件指针

D1057.c

原文件

#include <stdio.h>int main(void)
{float numA, numB, *ptr;numA = 4.5;numB = 6.8f;/*********Found************/ptr = numB;/*********Found************/printf("numA=%f, numB=%f\n", numA, ptr);return 0;
}	

改后文件

#include <stdio.h>int main(void)
{float numA, numB, *ptr;numA = 4.5;numB = 6.8f;/*********Found************/ptr = &numB;/*********Found************/printf("numA=%f, numB=%f\n", numA, *ptr);return 0;
}	

考查要点:

  1. 指针和变量的关系
  2. 取值和取址

D1058.c

原文件

#include <stdio.h>int main(void)
{ struct student{int num;char name[10];float score[3];} stu1 = {2012,  "WuHua",  {75.4f, 80, 92}}; struct student *ptr;/*********Found************/ptr = stu1;/*********Found************/printf("%s\n", ptr.name);return 0;
}

改后文件

#include <stdio.h>int main(void)
{ struct student{int num;char name[10];float score[3];} stu1 = {2012,  "WuHua",  {75.4f, 80, 92}}; struct student *ptr;/*********Found************/ptr = &stu1;/*********Found************/printf("%s\n", ptr->name);return 0;
}

考查要点:

  1. 指针和结构
  2. 用指针的方式访问结构成员:指向

D1059.c

原文件

#include <stdio.h>int main(void)
{ int *ptr, i, arrA[10];/*********Found************/___________________________;for (i=0; i<10; i++){scanf("%d", ptr++);}printf("\n");/*********Found************/___________________________;for(i=0;  i<10;  i++, ptr++){printf("%d ",*ptr);}printf("\n");return 0;
}

改后文件

#include <stdio.h>int main(void)
{ int *ptr, i, arrA[10];/*********Found************/ptr = arrA;for (i=0; i<10; i++){scanf("%d", ptr++);}printf("\n");/*********Found************/ptr = arrA;for(i=0;  i<10;  i++, ptr++){printf("%d ",*ptr);}printf("\n");return 0;
}

考查要点:

  1. 指针和数组的关系
  2. 用指针移动和遍历数组元素

D1060.c

原文件

#include <stdio.h>int main(void)
{ struct student{int num;char name[10];} stu[3], *ptr;int i;for (i=0; i<3; i++){scanf("%d,%s", &stu[i].num, stu[i].name);}/*********Found************/for (ptr=stu; __________; _________){printf("%d, %s\n", ptr->num, ptr->name);}return 0;
}

改后文件

#include <stdio.h>int main(void)
{ struct student{int num;char name[10];} stu[3], *ptr;int i;for (i=0; i<3; i++){scanf("%d,%s", &stu[i].num, stu[i].name);}/*********Found************/for (ptr=stu; ptr<stu+3; ptr++){printf("%d, %s\n", ptr->num, ptr->name);}return 0;
}

考查要点:

  1. 结构体基础知识
  2. 指针基础知识
  3. 数组基础知识
  4. 使用指针来遍历结构体数组

D1061.c

原文件

#include <stdlib.h>
#include <stdio.h>#define LEN sizeof(struct student)struct student
{int num;char name[20];struct student *next;
};struct student *creat(void);
void display(struct student *head);int main(void)
{struct student * head;head = creat();display(head);return 0;
}struct student *creat(void)
{struct student *p1, *p2, *head=NULL;int num;printf("请输入学号及姓名(学号输入为0时表示停止):\n");while (1){scanf("%d", &num);if (0 == num) {break;}p1 = (struct student *)malloc(LEN);p1->num = num;scanf("%s",  p1->name);if (NULL == head){head = p1;}else{p2->next = p1;}/*********Found************/___________________________;}if (head != NULL){p2->next = NULL;}/*********Found************/___________________________;
}void display(struct student *head)
{struct student *p1;p1 = head;while (p1 != NULL){printf("%d, %s ", p1->num, p1->name);p1 = p1->next;}
}

改后文件

#include <stdlib.h>
#include <stdio.h>#define LEN sizeof(struct student)struct student
{int num;char name[20];struct student *next;
};struct student *creat(void);
void display(struct student *head);int main(void)
{struct student * head;head = creat();display(head);return 0;
}struct student *creat(void)
{struct student *p1, *p2, *head=NULL;int num;printf("请输入学号及姓名(学号输入为0时表示停止):\n");while (1){scanf("%d", &num);if (0 == num) {break;}p1 = (struct student *)malloc(LEN);p1->num = num;scanf("%s",  p1->name);if (NULL == head){head = p1;}else{p2->next = p1;}/*********Found************/p2 = p1;}if (head != NULL){p2->next = NULL;}/*********Found************/return head;
}void display(struct student *head)
{struct student *p1;p1 = head;while (p1 != NULL){printf("%d, %s ", p1->num, p1->name);p1 = p1->next;}
}

考查要点:

  1. 结构
  2. 链表
  3. 遍历链表节点

D1062.c

原文件

#include <stdio.h>void findmax(int (*pArr)[4], int *pmax, int m, int n);int main(void)
{ int arr[3][4], *pa, max[3], i;printf("input 12 elements : \n");pa = arr[0];for (i=0; i<12; i++){scanf("%d", pa++);}findmax(arr, max, 3, 4);for (i=0; i<3; i++){printf("line %d's max = %d\n", i, max[i]);}return 0;
}void findmax(int (*pArr)[4], int *pmax, int m, int n)
{int i, j;for (i=0;  i<m;  i++, pmax++){/*********Found************/*pmax = ___________________;for (j=1; j<n; j++){/*********Found************/if (_______________ > *pmax){/*********Found************/*pmax = ___________________;}}}
}

改后文件

#include <stdio.h>void findmax(int (*pArr)[4], int *pmax, int m, int n);int main(void)
{ int arr[3][4], *pa, max[3], i;printf("input 12 elements : \n");pa = arr[0];for (i=0; i<12; i++){scanf("%d", pa++);}findmax(arr, max, 3, 4);for (i=0; i<3; i++){printf("line %d's max = %d\n", i, max[i]);}return 0;
}void findmax(int (*pArr)[4], int *pmax, int m, int n)
{int i, j;for (i=0;  i<m;  i++, pmax++){/*********Found************/*pmax = *(*(pArr+i));for (j=1; j<n; j++){/*********Found************/if (*(*(pArr+i)+j) > *pmax){/*********Found************/*pmax = *(*(pArr+i)+j);}}}
}

考查要点:

  1. 函数
  2. 指针
  3. 二维数组
  4. 行指针指向二级数组

D1063.c

原文件

#include <stdio.h>void change(int *p1, int *p2);
/*********Found************/
______sort(int *pArr, int n);int main( )
{int arr[20], *pa, i, n;printf("Please input the number n = ");scanf("%d", &n);printf("Please input the array elements : ");for (i=0, pa=arr;  i<n;  i++){scanf("%d", pa++); }/*********Found************/___________________________;printf("\n output : \n");for (i=0; i<n; i++){printf("%d   ", *(pa + i));}printf("\n");return 0;   
}void change(int *p1, int *p2)
{int tmp;tmp = *p1;*p1 = *p2;*p2 = tmp;
}/*********Found************/
______sort(int *pArr, int n)
{int i, *pa;for (i=n-1; i>0; i--){for (pa=pArr; pa<pArr+i; pa++){if (*pa > *(pa+1)){change(pa, pa+1);}}}/*********Found************/___________________________;
}

改后文件

#include <stdio.h>void change(int *p1, int *p2);
/*********Found************/
int * sort(int *pArr, int n);int main( )
{int arr[20], *pa, i, n;printf("Please input the number n = ");scanf("%d", &n);printf("Please input the array elements : ");for (i=0, pa=arr;  i<n;  i++){scanf("%d", pa++); }/*********Found************/pa = sort(arr, n);printf("\n output : \n");for (i=0; i<n; i++){printf("%d   ", *(pa + i));}printf("\n");return 0;   
}void change(int *p1, int *p2)
{int tmp;tmp = *p1;*p1 = *p2;*p2 = tmp;
}/*********Found************/
int * sort(int *pArr, int n)
{int i, *pa;for (i=n-1; i>0; i--){for (pa=pArr; pa<pArr+i; pa++){if (*pa > *(pa+1)){change(pa, pa+1);}}}/*********Found************/return pArr ;
}

考查要点:

  1. 函数
  2. 返回地址的情况,即指针函数

这篇关于成信大2021自动化专业-平时自主学习-C语言改错题解题参考-整理第08页的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

Python自动化处理PDF文档的操作完整指南

《Python自动化处理PDF文档的操作完整指南》在办公自动化中,PDF文档处理是一项常见需求,本文将介绍如何使用Python实现PDF文档的自动化处理,感兴趣的小伙伴可以跟随小编一起学习一下... 目录使用pymupdf读写PDF文件基本概念安装pymupdf提取文本内容提取图像添加水印使用pdfplum

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

GO语言中函数命名返回值的使用

《GO语言中函数命名返回值的使用》在Go语言中,函数可以为其返回值指定名称,这被称为命名返回值或命名返回参数,这种特性可以使代码更清晰,特别是在返回多个值时,感兴趣的可以了解一下... 目录基本语法函数命名返回特点代码示例命名特点基本语法func functionName(parameters) (nam

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Go语言使用Gin处理路由参数和查询参数

《Go语言使用Gin处理路由参数和查询参数》在WebAPI开发中,处理路由参数(PathParameter)和查询参数(QueryParameter)是非常常见的需求,下面我们就来看看Go语言... 目录一、路由参数 vs 查询参数二、Gin 获取路由参数和查询参数三、示例代码四、运行与测试1. 测试编程路

Python使用python-pptx自动化操作和生成PPT

《Python使用python-pptx自动化操作和生成PPT》这篇文章主要为大家详细介绍了如何使用python-pptx库实现PPT自动化,并提供实用的代码示例和应用场景,感兴趣的小伙伴可以跟随小编... 目录使用python-pptx操作PPT文档安装python-pptx基础概念创建新的PPT文档查看