一、PTA实验作业

题目1:统计一行文本的单词个数

1. 本题PTA提交列表

2. 设计思路

Begin

定义字符型变量ch,pre=‘ ’;
定义整型变量count;//用来记录单词个数
count←0;
while((ch←getchar())!='\n')
do{
if(ch!=' ' and pre →' ')
count 自增;
pre←ch;
}
output count; End

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

本道题类似于11月循环结构上机考试的一道题

当时提交时的错误提示显示我没有考虑到输入很多空格和只输入空格的情况,这次做题时突然想到,每次开始输入一个“单词”,除了第一个单词,其余单词的前面一定是有空格的,于是我定义了一个pre表示输入字符的前一个变量,先给pre赋上初值为空格,然后接下来每次输入字符时都令pre赋上ch的值,以此达到计数单词的目的(不过在写这个时才发现没有用数组来做,但是用数组也是差不多的,在开始的时候输入字符串遍历数组,后面的操作就差不多了)

题目2:找最长的字符串

1. 本题PTA提交列表(要提交列表,不是结果)

2. 设计思路

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

错误提示:

当时的代码是这样的(经过检查上面的代码没有错,那就只有最后输出错了)

后来仔细看了题目,才发现输出漏了一些东西,于是改成以下代码,果然全部正确了

题目3:删除字符串中的子串

1. 本题PTA提交列表(要提交列表,不是结果)

2. 设计思路

Begin

定义整型变量i,j,count=0;
定义字符数组s1[100],s2[100];
input s1,s2;
while s1[i]!='\0'
do{
if s2[count]←'\0' and count>0
then{
j→i-count;
while(s1[i]!←'\0')
s1[j++]→s1[i++];
s1[j]→'\0';
i→0;
count→0;
}
if s1[i]←s2[count]
count 自增;
else if (s1[i]←s2[0])
count→1;
else
count→0;
i自增;
if s2[count]←'\0' and count>0 /*当要删除的字串在s1末尾时*/
s1[i-count]→'\0';
output s1; End

3.代码截图

4.本题调试过程碰到问题及PTA提交列表情况说明。

这是一开始的代码

但是发现这样会把所有只要是子串中的字符都删掉,很明显题目的要求不是这样,于是上网参考别人的代码重新写了一个。

二、截图本周题目集的PTA最后排名。

三、同学代码结对互评

1.互评同学名称

曾文惠

2.我的代码、互评同学代码截图

我的代码:

曾文惠的代码:

3.我和同学代码不同在哪里?有哪些各自优势?你更喜欢哪种代码风格?如果同学代码有错的也请帮忙指出来哪里出问题。

曾文惠同学的代码与我的不同之处在于,她使用了strlen函数来计算字符串的长度,但是在本题中这一步是可以省略的,另外对于第一个单词的判断,她是在循环外先进行一次判断,而我的代码把这两步都合在一个循环里进行判断,虽然我们的思路差不多,但是我的代码要更加简洁,我更喜欢我的代码。

四、本周学习总结

1.你学会了什么?

1.1指针变量如何定义?

类型名 *指针变量名

如:

int *p;
char *cp;
float *fp;
double *dp1,*dp2;

需要特别注意的是:定义多个变量时,每一个指针变量前面都必须加上*

1.2 指针加法运算运用在哪种情况,2个指针变量能否相加?

指针的加法运算用在改变存储单元的位置,如“++p”、“(p)++”;

两个指针变量不能相加,指针变量表示地址,地址相加没有意义,但可以进行减法运算,表示两个地址之间的距离。

1.3 指针不赋初值,直接使用,会出现什么情况,请用DEVC验证,并截图展示?

程序运行失败。

1.4 课堂派上关于分离浮点数的整数部分和小数部分那题,请用DEVC验证实现,并在此贴图展示,同时说明哪句是指针变量做函数形参,函数实参应该怎么表示。指针变量做函数形参有什么用处?

第8行,指针变量作函数形参,指针变量需要在主函数有定义,函数实参需要加上&。

指针变量作为函数形参,可以将函数外部的地址传到函数内部,使得在函数内部可以操作函数外部的数据,并且这些数据不会随着函数的结束而被销毁。

1.5 请把课本的冒泡排序的函数改成指针变量做形参格式,并把代码写在底下,注意用markdown语法渲染。


void bubble (int *p ,int n)
{
int i,j,t;
for(i=0;i<n;i++)
for(j=0;j<n-i;j++)
if(*p>*(p+1))
{
t=*p;
*p=*(p+1);
*(p+1)=t;
}
for(i=0;i<n;i++)
printf("%d",*(p+i));
}

1.6 如何定义一个指针变量指向数组,如何用指针变量表示数组元素?

(1)让指针变量指向数组

int a[100],*p;
p=a;

(2)用指针变量表示数组元素

p1=a;      等价于 p1=&a[0];
p2=a+1; 等价于 p2=&a[1];
那么 *p1=a[0]; *p2=a[1];
*(p++)即可表示数组a中的元素

1.7 如何定义字符指针指向字符串?指针指向字符串后,初始位置在哪里?

定义字符指针指向字符串

char *sp="string";

指针指向字符串后,初始位置即字符串首字符的地址

1.8 利用字符指针操作字符串,如设计函数实现字符串连接,请在此贴图展示代码。说明指针表示字符的方法好处是什么?

好处:占用的存储空间小,只占用一个可以存放地址的内存单元,使用方便。

2.本周你不会内容有什么?

2.1 课堂派错题罗列及如何订正。

第七题:

订正:

应该选A,str是数组名,不能进行赋值。

第六题:

订正:

(其实是不小心选错了= =)p表示的是a[0]的地址,加上8表示的还是地址,所以D错,p表示的是a[0]的值,(p+9)表示的是a[0]+9,即10,所以A和C错误,B正确

第四题:

订正:

同第七题,a是数组名,是常量,不能改变其值,所以选D。

第二题:

订正:

1.num 2.p+n 3.max<*p

数组作为形参,只需要数组名;

q表示地址,所以条件应该也是地址。

第三题:

订正:

忘记返回指针导致的错误。

2.2 其他不会的?打算怎么解决

课堂派的第一题不知道错在哪里,打算问同学。

3.数组上机考试小结

3.1 那题错了,请罗列?

6-2,7-3

7-2,7-4还没来得及做

3.2 错题如何订正,为什么错了?

6-2:错误提示:

但是不清楚测试点simple2是什么

7-3:当时时间快结束了所以把代码提交一下作为保存,没想到对了几个测试点,还没来得及去订正。

PS:修改

1.3 指针不赋初值,直接使用,会出现什么情况,请用DEVC验证,并截图展示

结果是一个随机地址

指针未赋初值,指针访问一个随机地址里面存放的数据,是不合法的。

1.8指针表示字符的方法好处

C语言博客作业--字符数组的更多相关文章

  1. C语言博客作业—字符数组

    一.PTA实验作业 题目1:字符串转换成十进制整数 1. 本题PTA提交列表 2. 设计思路 (1)定义i为循环变量,number用于存放每一次转化的结果,flag用于判断是否为负数,p用于修改结果的 ...

  2. C语言博客作业--字符数组-陈张鑫

    一.PTA实验作业(4分) 题目1:7-5 查验身份证 1. 本题PTA提交列表(要提交列表,不是结果) 2. 设计思路(伪代码或流程图) 定义变量身份证个数n,合法个数count=0,flag=0, ...

  3. C语言博客作业字符数组

    一.PTA实验作业 7-12 IP地址转换 本题PTA提交列表 设计思路 3.代码截图 7-7删除字符串中的子串 本题PTA提交列表 设计思路 定义字符型数组s[81]储存主串,sub[81]储存子串 ...

  4. C语言第八次博客作业--字符数组

    一.PTA实验作业 题目1:查验身份证 1. 本题PTA提交列表 2. 设计思路 定义i,flag=1,z,m[11],a[19] 输入次数n for i=1 to n+1 gets(a) 加权求和在 ...

  5. C语言博客作业04——数组

    1.本章学习总结 1.1思维导图 1.2本章学习体会及代码量 1.2.1学习体会 这几周学习了数组,数组分为三大块:一维数组.二维数组和字符数组.数组相对于之前普通变量的好处就是可以储存数值,方便数据 ...

  6. C语言博客作业4——数组

    0.展示PTA总分 一维数组 二维数组 字符数组 1.本章学习总结 1.1学习内容总结 一维数组知识点: 无论是对一维数组还是二维数组进行应用时,我们对其下标的应用十分广泛. 1:一维数组的输入和遍历 ...

  7. C语言博客作业04数组

    0.展示PTA总分 1.本章学习总结 1.1 学习内容总结 1.int a[10];为定义数组,表示数组有10个数 2.数组的下标都是从0开始,到n-1结束 3.数组里元素的个数不能大于数组的长度 4 ...

  8. C语言博客作业04—数组

    0.展示PTA总分(0----2) 展示3张关于"数组题目集"分数截图. 1.本章学习总结(2分) 1.1 学习内容总结 整理数组这章学习主要知识点,必须包含内容有: (1)数组查 ...

  9. C语言博客作业5--指针

    C语言博客作业5--指针 1.本章学习总结(2分) 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里 ...

随机推荐

  1. class-k近邻算法kNN

    1 k近邻算法2 模型2.1 距离测量2.2 k值选择2.3 分类决策规则3 kNN的实现--kd树3.1 构造kd树3.2 kd树搜索 1 k近邻算法 k nearest neighbor,k-NN ...

  2. 启动就加载(一)----注解方式实现的。static项目启动的时候就加载进来(一般用于常用参数)

    一,案例 1.1,图片分析 1.2,代码 1.2.1,编写加载系统参数的servlet public class SysInitServlet extends HttpServlet { public ...

  3. 【原】Spring源码浅析系列-导入源码到Eclipse

    用了Spring几年,平时也断断续续在项目里看过一些源码,大多都是比较模糊的,因为一旦从一个地方进去就找不到方向了,只能知道它大概是做了什么事能达到这个功能或者效果,至于细节一般没有太深入去研究.后来 ...

  4. Inception模型和Residual模型卷积操作的keras实现

    Inception模型和Residual残差模型是卷积神经网络中对卷积升级的两个操作. 一.  Inception模型(by google) 这个模型的trick是将大卷积核变成小卷积核,将多个卷积核 ...

  5. [Python爬虫]使用Selenium操作浏览器订购火车票

    这个专题主要说的是Python在爬虫方面的应用,包括爬取和处理部分 [Python爬虫]使用Python爬取动态网页-腾讯动漫(Selenium) [Python爬虫]使用Python爬取静态网页-斗 ...

  6. 【BZOJ2843】极地旅行社(Link-Cut Tree)

    [BZOJ2843]极地旅行社(Link-Cut Tree) 题面 BZOJ 题解 \(LCT\)模板题呀 没什么好说的了.. #include<iostream> #include< ...

  7. 【BZOJ2186】沙拉公主的困惑(数论)

    [BZOJ2186]沙拉公主的困惑(数论) 题面 BZOJ 题解 考虑答案是啥 先假设\(n=m\) 现在求的就是\(\varphi(m!)\) 但是现在\(n!\)是\(m!\)的若干倍 我们知道 ...

  8. 【经验随笔】Restlet Client发送XML格式参数消息

    背景介绍 Restlet Client是一款模拟客户端发送http请求的chrome插件,可以作为驱动调试后台程序,个人觉得比POSTMAN好用.CXF是一款发布restful服务的开源组件. 编写r ...

  9. div闪一下就消失

    <div id="saveCode" class="center" style="display:none;width:300px;height ...

  10. Java Swing应用程序JLable超链接

    在HTML中设置一个超链接是很容易的,使用<a></a>标签就可以完成了. 在客户端应用程序中,并没有这样的标签,但是可以使用按钮来实现,But 有时候就是想好看一点,不想要按 ...