1.本章学习总结

1.1思维导图

1.2本章学习体会及代码量学习体会

1.2.1 学习体会

  • 理解了指针在代码中的使用方法,学会使用指针进行参数操作
  • 学会了结构体的定义方式与结构体的使用
  • 经过持续一个周末的大作业重写,加强了指针在函数中的应用,学会利用数组与指针的关系进行操作

1.2.2 代码累计

2.PTA总分

2.1截图PTA中的排名得分

2.2 我的总分

指针:125

总分:125

3. PTA实验作业

3.1 PTA题目1

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

3.1.1 算法分析

输入字符串a
mark=strlen(a)
for i=mark-1 to 0
if a[i]!=空格 且 ( a[i-1]=空格 或 i = 0) //a[i]为单词首字母
p=&a[i]
flag++
if flag!=1
输出空格
end if
do
{
输出*p
p++ //指针移到下一位
}while *p!=空格 且 *p!=\0
end if
end for

3.1.2 代码截图

3.1.3 测试数据

3.1.4 PTA提交列表及说明

说明:

Q1:数组范围不够大造成越界

A1:数组范围加大至500001

Q2:发现最开始的思路出现了大量重复的无用判断

A2:修正后运行时间大幅缩短

4.大作业

4.1 介绍改进函数

4.1.1 函数CreateExp

mk标记数组初始位置
if level=1
mark=1 //一个操作符
else
mark=2 //二个操作符
end if
指针移动至第一个操作符
do
{
do
{
//调用CreateOp函数填入运算符,同时指针向前移动 //调用CreateNum函数填入运算数,同时指针向前移动 //指针移动到下一个操作符的位置
mark--
}while(mark)
*exp='='
*exp+1='\0' //结束字符串
调用CreateNum函数填入最后一个运算数
exp=mk //指针回到字符串起始位置
}while(调用IsExp函数查错)
输出字符串



下级函数CreateNum

根据level生成随机数
do
{
p-- //指针前移
*p=a[i]%10+'0'
a[i]=a[i]/10
}while(a[i]!=0)
返回指针位置

关于函数CreatNum中为什么不使用rand()%100和rand%1000

  • 使用rand()%100和rand%1000时发现了神奇的bug

  • 计算式出现了不可能存在的4位数字
  • 输出三个运算数查错

  • 发现运算数没有问题
  • 观察输出的计算式 发现bug所在
  • 由于使用以下式子移动指针

  • 导致指针移动时留下了 红色标记的空位 并被随机填充

  • 将这类情况一一用IsExp函数剔除,感觉不如直接在生成时直接避免

下级函数CreateOp

根据level生成除数num
flag=rand()%num
根据flag生成相应运算符
*q=生成的运算符
返回指针位置

4.1.2 函数IsExp

if level=1 且 操作符 为 /
if 运算数2 为 0
return 1
if 计算式不能整除
return 1
end if
return 0



在CreateExp函数中的使用方法

4.1.3 函数ComputeExp

定义数组a存放运算数和得数
定义字符数组op存放运算符
for (i=0 ,j=0;(exp+i)!='=';i++) //遍历计算式
if *(exp+i)为数字
a[j]=a[j]*10+*(exp+i)-'0' //将数字字符存入a[i]中
else
op[j]=*(exp+i) //运算符存入op
j++
end if
根据运算符进行计算
将结果存入a[3]
if a[2]存在
进行第二步运算
将结果存入a[3]
end if
return a[3] //返回正确答案

4.2 和原版的比较

4.2.1 函数CreateExp

原版代码:



  • 原版的生成运算符方式头异常的铁,使用嵌套二层switch把所有可能的情况全部列举出来,形成大量重复代码
  • 新版代码采用指针移动的方法输入字符,简化了整个函数
  • 原版直接输出计算式的符号与数字
  • 新版将计算式存入字符串后输出,同时也将计算式保留,使函数ComputeExp可以使用该计算式

4.2.2 函数IsExp

emmm原版根本没有这个函数

4.2.3 函数ComputeExp

原版代码:(见4.2.1图)

  • 原版代码在生成运算符后立即对前后两个运算符进行运算,思路过于直白,重复代码过多
  • 新代码将输出的字符串逆向转换为数字和运算符,并计算出正确答案

4.3 改进大作业总结

  • 原版的大作业只用了183行代码/三个函数完成了四则运算的操作,而且检查输入错误的方法异常诡异,完全没有半点改的空间
  • 主要是因为某位老哥在他上次的作业完美重现了我诡异的代码,事实证明改了变量名代码查重就没用了,我想看一下那位老哥要厉害到什么程度才能改我上次做的神奇玩意
  • 所以本次大作业除了输入提示和上次长得一样,其它全盘推翻重写
  • 学会细化函数的分工,使main函数尽可能简洁
  • 用输入字符串代替输入字符,防止程序出错
  • 用指针代替了全局变量实现函数间参数改变
  • 用查错函数IsExp解决了小学生四则运算中出现的我也不会做的题,如:3/7
  • 有多处使用了字符串转数字/数字转字符串的操作,一时半会没法整出一个统一的函数进行转换,下次将再改进

C博客作业05—指针的更多相关文章

  1. C语言博客作业05——指针

    1.本章学习总结 1.1思维导图 1.2本章学习体会及代码量 1.2.1学习体会 可能因为之前数组那块儿的作业拖得太久了,以至于我觉得指针学的好快,还没反应过来就教完了,然后一开始做题的时候,就是一脸 ...

  2. C语言l博客作业05

    问题 回答 这个作业属于哪个课程 C语言程序设计ll 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/SE2019-2/homework/9830 我在这 ...

  3. C语言I博客作业05

    内容 答案 这个作业属于哪个课程 C语言程序设计II 这个作业要求在哪里 C语言I作业05 我在这个课程的目标是 更熟练的运用编译函数问题 这个作业在哪个具体方面帮助我实现目标 PTA实验作业 参考文 ...

  4. C语言|博客作业05

    这个作业属于哪个课程 C语言程序设计II 这个作业的要求在哪里 https://edu.cnblogs.com/campus/zswxy/CST2019-1/homework/9825 我在这个课程的 ...

  5. c语言1博客作业05

    一.本周作业头 这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/SE2019-3/homework/9831 我 ...

  6. C语言Ⅰ博客作业05

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/CST2019-3/homework/9827 我在这个课程的目 ...

  7. C语言博客作业05

    这个作业属于哪个课程 C语言程序设计II 这个作业要求在那里 https://edu.cnblogs.com/campus/zswxy/CST2019-3/homework/9827 我在这个课程的目 ...

  8. DS博客作业05——树

    1.本周学习总结 1.1思维导图 1.2学习体会 学习:相比于之前的数据结构,树多了很多性质,相应的也多了很多计算题,不得不说,专有名词也是颇多.觉得树最独特的地方就是它的兄弟.孩子结点,用以组成了它 ...

  9. DS博客作业05—树

    1.本周学习总结 1.1思维导图 1.2学习体会 本周学习了树的相关知识,了解了树结构体的应用和基本操作 学习了二叉树的遍历,创建以及哈夫曼树的相关操作 通过树的构建等操作熟练了递归的使用 2.PTA ...

随机推荐

  1. c#,条码

    static void Generate2(string text){ BarcodeWriter writer = new BarcodeWriter(); //使用ITF 格式,不能被现在常用的支 ...

  2. 28.OGNL与ValueStack(VS)-总结$ # %的区别

    转自:https://wenku.baidu.com/view/84fa86ae360cba1aa911da02.html $用于i18n和struts配置文件 #取得ActionContext的值 ...

  3. Redhat 7.2 编译安装PostgreSQL 10

    1.环境说明 CentOS7.2 postgresql10.4 2.下载 postgresql的官方地址 https://www.postgresql.org/ftp/source/ 在下载列表中根据 ...

  4. Vue 实现微信 jssdk 扫码, 上传图片

    流程 1: 配置微信公众号JS域名 2:前端发送URL后台获取JSSDK配置, 后台Service代码如下, 修改2处位置: WeixinUtil.APPID => 当前公众号APPID Wei ...

  5. 解决Notepad++ Plugin Manager无法加载插件的方法

    今天正好安装了Notepad++,结果发现Plugin Manager里插件一个也没有,网上对应的方法都没有,最后无意间看到Plugin Manager Settings 里的提示,试了一下居然成功了 ...

  6. 进程组&Session

    [进程组] 1. getpgrp(), getpgid(0) 可获取进程组id, 进程组长的pid等于pgid. 如果进程组长exit, 则进程组依旧存在, 组内其它进程的组ID仍然是之前的ID, 即 ...

  7. awk使用

    [awk使用] 例:awk -F ':' '{print $1"\t"$7}' 参考:http://www.cnblogs.com/ggjucheng/archive/2013/0 ...

  8. 获取set()和push()方法向值栈放的数据

    ------------------siwuxie095 获取 set() 方法向值栈放的数据 1.具体步骤 (1)在 Action 中使用 set() 方法向值栈放数据 (2)在 JSP 页面中从值 ...

  9. Win10 Cygwin Cd Permission denied

    问题描述 在win10或者win系统上面,使用cygwin的时候, 有时候会出现, 权限问题. 即使是管理员也不行. 问题分析 这个问题,我个人觉得,主要是使用不当造成的. 也就是说, 可能使用chm ...

  10. 1014_C语言的文法

    程序-> <外部声明><程序><外部声明> 外部声明-> <函数定义>|<声明> 函数定义-> <函数类型>& ...