C语言博客-指针
一、PTA实验作业(5分)
题目1:6-1 两个4位正整数的后两位互换
1. 本题PTA提交列表
2. 设计思路
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
- 无
题目2:6-3 统计大于等于平均分人数
1. 本题PTA提交列表
2. 设计思路
定义 *b 用于储存s首位置,sum用于求和
若*s不等于0
sum+=*s;
s++;
end
平均分*aver=sum/人数
n=0用于统计及格人数
若*b不等于0
如果 *b大于或等于*aver
n++
b++
end
返回 n
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
1.答案正确但输出错误(不相信所以交了两次)
不要处理指针首地址本身,新建一个指针来处理
题目3:6-10 字符串串动变化
1. 本题PTA提交列表
2. 设计思路
定义 整型变量max储存最大值,循环变量g,最大字符下标i;
字符型 temp用于暂时储存字符,*q用于储存p的首位置
q=p
max=*p的ASCII数
若 *p不等于\0
if *p的ASCII数 大于 max
max 等于 *p的ASCII数
i++;
p++
end
for g=i to g=0
交换 *(p+g)和*(p+g-1)
end for
- 今天写博客的时候发现一个问题:如果输入的字符串不是按照ASCII数按照大小输入,则我的代码不成立
3.代码截图
4.本题调试过程碰到问题及PTA提交列表情况说明。
- 错误一:p=*q
- 错误二:交换时使用了双循环
- 错误三:循环次数错误
二、截图本周题目集的PTA最后排名。(2分)
三、阅读代码(2分)
- 因为我自己做不出来,所以和军霖同学要了这道题目的代码了解
- 吴军霖同学关于6-11报数的代码1:
void CountOff( int n, int m, int out[] ){
int off=1,cnt=0,i;
static int flag[MAXN];
for(i=1;off<=n;i++){
cnt+=!flag[i];
if(cnt%m==0&&!flag[i]) {
flag[i]=1;
out[i-1]=off++;
}
if(i==n) i=0;
}
- 它的功能:给出每个人的退出顺序编号。
- 优势:
- 1.首先可以看出军霖同学的代码十分简洁,像
if(flag[i])
cnt++;
他直接简化为
cnt+=!flag[i];
- 2.他判断是否出圈的方式很巧妙,用数组flag[MAXN]表示,当flag等于1时,表示没有出圈,当flag=0时表示出圈;
- 3.关于让我比较头疼的就是如何使一个数列以一个圈的方式循环,
军霖同学以
if(i==n) i=0;
的方式判断语句是否到达最后一个人,并赋予0,从头开始循环,即以一个圈的形式进行;
- 吴军霖同学关于7-7 删除字符串中的子串
char s[81],sub[81];
gets(s);
gets(sub);
int i,u,v;
do{
for(i=0,u=0; s[i] ;){//以s到最后一个字符为结束
if(s[i]==sub[0]){//主串中遇到与子串第一个字符相等的开始判断接下来的是否会相等
for(v=i+1; sub[v-i] ;v++) //循环条件为sub[v-i],即子串到最后一个字符,减少了许多变量
if( s[v]!=sub[v-i] )
break;
if(!sub[v-i]) i=v;//如果子串出现,就给主串加上子串的长度
}
s[u++]=s[i++];//即满足了s[u]=s[i],又进行了i++,u++;
}
s[u]='\0';//for循环结束 后给s[u]加上结束标识符
}while(u!=i);//新的字符串中也会有子串的出现
puts(s);
return 0;
}
(备注是我自己对该代码的理解)
- 功能:输入2个字符串S1和S2,要求删除字符串S1中出现的所有子串S2,即结果字符串中不能包含S2。
- 优势:思路很清晰,代码精简,虽然精简比较难读懂,但这也是我们今后的目标
- (1)循环条件
for(v=i+1; sub[v-i] ;v++)
循环条件为sub[v-i],即子串到最后一个字符,减少了许多变量
- (2)录入除子串外字符的方式
s[u++]=s[i++];
即满足了s[u]=s[i],又进行了i++,u++;
- (3)用do-while循环语句对新字符也出现子串的情况进行了判断
四、本周学习总结(1分)
1.自己总结本周学习内容。
(1)什么是结构?结构和数组有什么区别
- 结构:结构类型是一种允许程序员把一些一些数据分量聚合成一个整体的数据类型。一个结构中包含的每个数据分量都有名字,这些数据分量称为结构成员或者结构分量,结构成员可以是C语言中的任意变量类型
- 和数组的区别:数组中所有元素的数据类型必须是相同的,而结构中各成员的数据类型可以不同
(2)有几种结构的定义形式
- 1.混合定义:在定义结构类型的同时定义结构变量
struct 类型名{
类型名 结构成员1;
类型名 结构成员2;
...
类型名 结构成员n;
}结构变量名表;
注意:这里的分号不能漏掉.
- 2.嵌套定义:在定义结构成员时所使用的数据类型也可以是结构类型
例如:
struct address{
char city[10];
};
struct nest_student{
int num;
struct address addr;};
注意: struct address addr;};.
注意:必须先定义成员的结构类型,再定义主结构类型.
- 3.无类型名定义
例如:
struct {
类型名 结构成员1;
类型名 结构成员2;
...
类型名 结构成员n;
}结构变量名表;
注意:这种做法导致后来无法再定义这个类型的其他结构变量,所以一般建议前面两种.
(3)如何引用结构成员变量
结构变量名.结构成员名
注意:中间的那个点.
由于结构成员运算符的优先级属于最高级别,所以一般情况下都优先执行。
只有相同类型的变量之间才可以直接赋值
4)什么是结构数组?
- 结构数组是结构与数组的结合体
格式如下:
- 结构数组是结构与数组的结合体
struct student students[50]
- 2.其初始化与二位数组的初始化类似
- 3.对结构数组成员的引用
结构数组名[下标].结构成员名
(5)什么是结构指针?
- 1.结构指针就是指向结构类型变量的指针
- 2.结构指针的值实际上是结构变量的首地址,即,第一个成员的地址.
- 3.用*p访问结构成员
如:
01.(*p).num=101;
注意:(p)中的括号是不可以少的,因为成员运算符‘.’的优先级高于‘’的优先级.
02.p.num=101;
03.p->num=101;
2.罗列本周一些错题。
课堂派
- 1.预习作业
- 答案是语法错误,
要么
(*p).str++
要么
p->str++
- 答案是D. A中的“p++”也是地址,与p的用法相同是成立的,stu最大为stu[2],stu[3]越界了。
C语言博客-指针的更多相关文章
- C语言博客05--指针
C语言博客05--指针 1.本章学习总结 1.1 思维导图 1.2 本章学习体会及代码量学习体会 1.2.1 学习体会 在本周的学习过程中,我们学习了指针的用法.说实话,指针的用法有点绕,之前一直没搞 ...
- C语言博客作业6---结构体&文件
C语言博客作业6---结构体&文件 1.本章学习总结(2分) 1.1思维导图 请以思维导图总结本周的学习内容.如下图所示: 1.2.学习体会 描述本周学习感受,也可以在这里提出你不理解地方.对 ...
- C语言博客作业5--指针
C语言博客作业5--指针 1.本章学习总结(2分) 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里 ...
- C语言博客作业06——结构体&文件
C语言博客作业06--结构体&文件 1.本章学习总结 1.1思维导图 1.2.本章学习体会 在本周的学习中,我们学习了关于结构体和文件的内容.结构体的本身并不难,但以结构体为基础的链表还是让我 ...
- C语言博客作业4--数组
C语言博客作业4--数组 1.本章学习总结 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里提出你不 ...
- C语言博客作业3--函数
C语言博客作业3--函数 1.本章学习总结 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里提出你不 ...
- C语言|博客作业10
问题 回答 C语言 博客作业10 这个作业要求在哪里 作业要求 我在这个课程的目标是 熟练循环语句的用法 这个作业在哪个具体方面帮助我实现目标 pta作业 参考文献 <C语言程序设计> 1 ...
- C语言博客作业05——指针
1.本章学习总结 1.1思维导图 1.2本章学习体会及代码量 1.2.1学习体会 可能因为之前数组那块儿的作业拖得太久了,以至于我觉得指针学的好快,还没反应过来就教完了,然后一开始做题的时候,就是一脸 ...
- C语言博客作业——函数
一.PTA实验作业 题目1:6-6 使用函数输出水仙花数 1.本题PTA提交列表 2. 设计思路 int narcissistic( int number ) //函数定义 1.定义整数型变量a.i分 ...
随机推荐
- sql语句中的left join,right join,inner join的区别
left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录 inner join(等值连接) ...
- PC响应式、固宽布局思想
截止目前,国内绝大多数内容为主的网站(知乎,果壳,V2EX,网易新闻等)均使用内容区定宽布局,大多数电商网站(网易考拉,京东,聚美优品)也使用了内容区定宽的布局,也有些网站使用了自适应布局. 如果不明 ...
- WebView的使用--Hybrid App
App页面是运行在WebView中的,一个App页面对应一个WebView,本例实现两个WebView之间的跳转. 实现过程(用到了MUI框架): 1.页面标识+跳转按钮(index.html.mai ...
- PyTorch官方中文文档:torch.nn
torch.nn Parameters class torch.nn.Parameter() 艾伯特(http://www.aibbt.com/)国内第一家人工智能门户,微信公众号:aibbtcom ...
- Python基础_函数闭包、调用、递归
这节的主要内容是函数的几个用法闭包,调用.递归. 一.函数闭包 对闭包更好的理解请看:https://www.cnblogs.com/Lin-Yi/p/7305364.html 我们来看一个简单的例子 ...
- Java 容器之Hashset 详解
Java 容器之Hashset 详解.http://blog.csdn.net/nvd11/article/details/27716511
- link 标签
link标签 主要是引用外部文件 rel属性 规定当前文档与被链接文档之间的关系 alternate,author,help,icon,licence,next,pingback,prefetch,p ...
- IDEA2017版本打可运行jar包并运行
一.打JAR包 JAR:From modules with dependencies 将依赖一起打包 一般依赖放在与xx.jar同级的libs文件夹中 敲黑板,下图第一个框是输出jar包的位置,第二 ...
- iptables 学习
本博客是学习慕课网课程 用iptables搭建一套强大的安全防护盾 整理而成 iptables相当于在ip层挂载一个hook point对用户进行控制 组成: 四张表+ 五条链(hook point) ...
- 【Unity与23种设计模式】适配器模式(Adapter)
GoF中定义: "将一个类的接口转换成为客户端期待的类接口.适配器模式让原本接口不兼容的类能一起合作." 适配器模式与装饰模式有一定的相似之处 两者都是在着手解决C#不能多继承的问 ...