成信大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

相关文章

C语言小项目实战之通讯录功能

《C语言小项目实战之通讯录功能》:本文主要介绍如何设计和实现一个简单的通讯录管理系统,包括联系人信息的存储、增加、删除、查找、修改和排序等功能,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录功能介绍:添加联系人模块显示联系人模块删除联系人模块查找联系人模块修改联系人模块排序联系人模块源代码如下

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

基于Go语言实现一个压测工具

《基于Go语言实现一个压测工具》这篇文章主要为大家详细介绍了基于Go语言实现一个简单的压测工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录整体架构通用数据处理模块Http请求响应数据处理Curl参数解析处理客户端模块Http客户端处理Grpc客户端处理Websocket客户端

使用SQL语言查询多个Excel表格的操作方法

《使用SQL语言查询多个Excel表格的操作方法》本文介绍了如何使用SQL语言查询多个Excel表格,通过将所有Excel表格放入一个.xlsx文件中,并使用pandas和pandasql库进行读取和... 目录如何用SQL语言查询多个Excel表格如何使用sql查询excel内容1. 简介2. 实现思路3

Go语言实现将中文转化为拼音功能

《Go语言实现将中文转化为拼音功能》这篇文章主要为大家详细介绍了Go语言中如何实现将中文转化为拼音功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 有这么一个需求:新用户入职 创建一系列账号比较麻烦,打算通过接口传入姓名进行初始化。想把姓名转化成拼音。因为有些账号即需要中文也需要英

Go语言使用Buffer实现高性能处理字节和字符

《Go语言使用Buffer实现高性能处理字节和字符》在Go中,bytes.Buffer是一个非常高效的类型,用于处理字节数据的读写操作,本文将详细介绍一下如何使用Buffer实现高性能处理字节和... 目录1. bytes.Buffer 的基本用法1.1. 创建和初始化 Buffer1.2. 使用 Writ

深入理解C语言的void*

《深入理解C语言的void*》本文主要介绍了C语言的void*,包括它的任意性、编译器对void*的类型检查以及需要显式类型转换的规则,具有一定的参考价值,感兴趣的可以了解一下... 目录一、void* 的类型任意性二、编译器对 void* 的类型检查三、需要显式类型转换占用的字节四、总结一、void* 的

Python Invoke自动化任务库的使用

《PythonInvoke自动化任务库的使用》Invoke是一个强大的Python库,用于编写自动化脚本,本文就来介绍一下PythonInvoke自动化任务库的使用,具有一定的参考价值,感兴趣的可以... 目录什么是 Invoke?如何安装 Invoke?Invoke 基础1. 运行测试2. 构建文档3.

Windows自动化Python pyautogui RPA操作实现

《Windows自动化PythonpyautoguiRPA操作实现》本文详细介绍了使用Python的pyautogui库进行Windows自动化操作的实现方法,文中通过示例代码介绍的非常详细,对大... 目录依赖包睡眠:鼠标事件:杀死进程:获取所有窗口的名称:显示窗口:根据图片找元素:输入文字:打开应用:依

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

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