一、PTA实验作业

题目1:简化的插入排序

1. 本题PTA提交列表

2. 设计思路

  1. 1)定义n,number,i,j,temp;
  2. 2)输入n;
  3. 3)定义数组a[n+1]; //把所有的数都放入数组中
  4. 4for(i=0;i<n;i++){
  5. 输入number
  6. a[i]=number;
  7. }
  8. 5)输入要插入的数(a[n]);
  9. 保留a[n]的值;
  10. 6for(j=0;j<n;j++){ //找出temp的位置
  11. if(temp<a[j])
  12. 结束循环;
  13. }
  14. 7for(i=n;i>j;i--)
  15. a[i]=a[i-1];
  16. 8)要插入的数为a[j];
  17. 9for(i=0;i<n+1;i++)
  18. 输出数组;

3.代码截图。

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

  • 还没有输入要插入的数就已经将原数组输出了; 改正后要插入的数插入位置没错,但是值被改变了;

  • 经过调试发现赋值语句出错,导致要插入的数被更改成前一个比它小的数的值;



    用另一个数来存放这个要插入的数即可。

题目2:加法口诀表

1. 本题PTA提交列表



2. 设计思路

  1. 1)定义四个循环变量i,j,k,Nn为正整数,repeat为计算次数;
  2. 2)输入repeat
  3. 3for(N=1;N小于等于repeat;N++){
  4. 输入n 输出‘+’;
  5. 定义 b[i], j=0;
  6. 4 for(i=0;i小于n;i++){ //把数存放在b[]中,
  7. b[i]=1n(++j可以实现)
  8. if(i<n-1) 输出右4b[ i ];
  9. if(i==n-1) 直接输出b[ i ]并换行;
  10. }
  11. 5 for(i=0;i小于n;i++){ //每一行的输出规律
  12. k=b[i];
  13. printf("%-4d",k);
  14. for(j=1;j<=i+1;j++){
  15. if(j<i+1) printf("%-4d",++k);
  16. if(j==i+1) printf("%d\n",++k);
  17. }
  18. }
  19. }

3.代码截图。

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

  • 本题刚开始的思路其实不是这个样子,本来用了一个二维数组,后来发现规律比较简单,可用一个一维数组完成;刚开始漏掉了reapeat,而调试时repeat一直用1没注意到,所以即使输出结果一样但是结果错误;

  • 改成一维数组时有些条件什么的乱掉了,导致之后列项的b[ i ]一直都是1,调试发现用于条件问题执行过程中跳过了一个if 语句导致了b[ i ]的值出错。

题目3: 杨辉三角

1. 本题PTA提交列表

2. 设计思路

  1. 1)定义number用于计算a[i][j]的值;
  2. 2)输入n
  3. 3if(n<10){ (当输入的n符合条件时)
  4. 4 定义二维数组 a[n][n];
  5. 5 for(i=0;i<n;i++){
  6. for(j=0;j<=i;j++){ (按条件输出a[i][j])
  7. if(i>=1j>=1)
  8. 计算number的值;
  9. if(j==0j==i)
  10. 第一列和i=j时都为1时,输出1
  11. else
  12. 输出number;
  13. 按要求输出a[i][j];
  14. }
  15. 每输完一行就换一行;
  16. }
  17. }

3.3.代码截图。

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

  • 第一列和i=j时都为1时,输出1没有问题;但是number的值一直出错

    可能是number的表达式存在问题,没有办法正常输出值,不确定是否可以这样计算;







    条件出错跳过第一个number的计算,导致接下来number的值都错了!仔细检查发现number应该从第二行开始就要进行计算,而条件是大于1的时候即从第三行开始;所以导致了number的值出错,改成大于等于1即可。

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

PTA排名

三、同学代码结对互评(1分)

1.互评同学名称

林岑

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

我的代码:

同学的代码:

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

  • 不同:我的代码:1.直接把年份递增然后放入数组中;2.分析年份各位数字的不同个数相对应的数字之间相等情况的次数,根据结果是否符合来判断是否达到要求;3.输出结果时让其自动补零;

    同学的代码:1.每次判断完再改变年份重新放到数组中;2.利用嵌套循环判断年份各位数字的不同个数,达到题目要求的个数后跳出循环即可;重复执行直到满足要求;3.列出对应情况的结果,按相对应的形式输出。
  • 也许自己的代码比较冗长,但是还是会更喜欢自己的代码;同学的判断方式比较快捷,我的就比较费功夫些。

四、本周学习总结(3分)

1.你学会了什么?

1.1 C中如何存储字符串?

  • 初始化数组,赋值或输入。

1.2 字符串的结束标志是什么,为什么要结束标志?

  • 结束标志是'\0',因为它表示空操作,无法输入;一旦输入它就表示字符串输入结束。而且由于字符串并没有明确地给出有效字符的个数,只规定在字符串结束符‘\0’之前的字符都是有效字符,一般用字符串结束符‘\0’来控制循环。

1.3 字符串输入有哪几种方法?

  • 赋初值;
  • 用scanf输入,字符串的格式控制说明为%s,遇到回车或空格就结束输入;
  • gets():读取字符串直到换行符结束,但换行符会被丢弃,然后在末尾添加'\0'字符。

1.4 数字字符怎么转整数,写个伪代码?

  1. 举例: char b;
  2. b='10';
  3. 输出十进制:'10'-'0';
  4. 输出:10

1.5 16进制、二进制字符串如何转10进制?写伪代码?

  1. 定义字符串转成十进制的函数:
  2. {
  3.   定义 i,m,temp=0,n;
  4. 获得十六进制的长度为m
  5. for(i=0;i<m;i++)
  6. {
  7. if(表示的是字母)
  8. n=s[i]-'a'+10;
  9. else(数字)
  10. n=s[i]-'0';
  11. temp=temp*16+n;
  12. }
  13. 主函数:
  14. char s[10];
  15. 输入字符串;
  16. 调用函数;
  17. 输出结果;

2.本周的内容,你还不会什么?

  • 课堂派



    判断字符数组的长度,刚开始并不是很明白'\0'是否包括在有效长度内;x要自己排进数组,所以需要一个结束符来结束,而y已经输入好了应该不需要加上去。
  • PTA

  1. int n,i=0,j=0,k,number,max,min,max1,max2,min1,flag=0;
  2. scanf("%d\n",&n);
  3. int a[n][n];
  4. for(i=0;i<n;i++) //输入各个元素的初值
  5. for(j=0;j<n;j++){
  6. scanf("%d",&number);
  7. a[i][j]=number;
  8. }
  9. for(i=0;i<n;i++){ //遍历数组
  10. max=a[i][0];max1=i; //该行第一列的元素为最大数
  11. for(j=1;j<n;j++){
  12. if(a[i][j]>max){ //找出行最大数
  13. max2=j;
  14. max=a[i][j];
  15. }
  16. }
  17. min=a[0][max2];min1=0; //该列第一行的数为最小数
  18. for(k=0;k<n;k++){
  19. if(a[k][max2]<min){ //在该列找列最小数
  20. min1=k;
  21. min=a[k][max2];
  22. }
  23. }
  24. if(max1==min1){ //当这两个数是同一个数时
  25. printf("%d %d",min1,max2);
  26. flag=1;
  27. break;
  28. }
  29. }
  30. if(i==n&&flag==0) //一直没找到
  31. printf("NONE");

找鞍点的题,明明找的是行最大列最小的数,调试完还是不明白为什么结果不对。

3.期中考试小结

3.1 你认为为什么没考好?

  • 复习不够认真,有些没复习到知识点已经遗忘了;平时对知识点掌握的就不够牢,课后没有花时间温习;
  • 做题速度慢,写编程题的时候时间有点紧张了;
  • 思路不够清晰,导致编程题得分率很低。

3.2 罗列错题。

  • 选择题第六题—判断正确的C语言语句:B和C都很像正确答案,但是C结束后分号,因为细节而导致失分;
  • 填空题—第七空:题意比较明确,判断输入的字符是否是换行符,但是太着急了写了个ch,却忘记了应该要不断地输入,答案是ch=getchar()。
  • 改错题—第二题:这题的程序读起来比较难一点,如果没有题目的提示可能还不能完全理解题意;程序中有两个表达式错误没找出来:第一个n++,第一个分母的变化规律是n+2的阶乘,所以应改为n+=2;第二个:term的值,分母应该是(n+1)*(n+2),但是由于运算等级的关系,如果像题目那么写的话,(n+2)会变成分子!
  • 编程题—第一题:随机数





    不知道如何产生要求内的随机数;不过这周老师已经补充过这个知识点了。

3.3 下半学期要怎么调整C的学习?

  • 多手写伪代码,一些细节和规范要注意;
  • 不仅花时间打代码,还要掌握相关的知识点;
  • 研究一些相关的知识,不只是单纯的局限于课堂;
  • 可以看看同学的代码,既可以拓展思路;又可以提高阅读代码的能力。

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

  1. C语言博客作业--数组

    一.PTA实验作业 题目1.求整数序列中出现次数最多的数 1.本题PTA提交列表 2.设计思路 定义整形变量n,max,count分别表示整数个数,出现次数最大值,出现次数.定义循环变量i,j. 输入 ...

  2. C语言博客作业6---结构体&文件

    C语言博客作业6---结构体&文件 1.本章学习总结(2分) 1.1思维导图 请以思维导图总结本周的学习内容.如下图所示: 1.2.学习体会 描述本周学习感受,也可以在这里提出你不理解地方.对 ...

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

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

  4. C语言博客作业4--数组

    C语言博客作业4--数组 1.本章学习总结 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里提出你不 ...

  5. C语言博客作业3--函数

    C语言博客作业3--函数 1.本章学习总结 1.1思维导图 请以思维导图总结本周的学习内容,如下图所示: 1.2本章学习体会及代码量学习体会 1.2.1学习体会 描述本周学习感受,也可以在这里提出你不 ...

  6. C语言博客作业06——结构体&文件

    C语言博客作业06--结构体&文件 1.本章学习总结 1.1思维导图 1.2.本章学习体会 在本周的学习中,我们学习了关于结构体和文件的内容.结构体的本身并不难,但以结构体为基础的链表还是让我 ...

  7. C语言|博客作业10

    问题 回答 C语言 博客作业10 这个作业要求在哪里 作业要求 我在这个课程的目标是 熟练循环语句的用法 这个作业在哪个具体方面帮助我实现目标 pta作业 参考文献 <C语言程序设计> 1 ...

  8. C语言博客作业08

    C语言I博客作业08](https://www.cnblogs.com/490-85-00-58-/p/11863312.html) 问题 回答 这个作业属于那个课程 C语言程序设计II 这个作业要求 ...

  9. C语言|博客作业12-学期总结

    我学到的内容 我的收获 第一次:https://www.cnblogs.com/tongyingjun/p/11563433.html:总结:初步了解了C语言.代码.博客园和Markdown语法. 第 ...

随机推荐

  1. winform自动更新程序实现

    一.问题背景 本地程序在实际项目使用过程中,因为可以操作电脑本地的一些信息,并且对于串口.OPC.并口等数据可以方便的进行收发,虽然现在软件行业看着动不动都是互联网啊啥的,大有Web服务就是高大上的感 ...

  2. 实现一个简单的订阅与发布模式的代码块,和redux

    /** * Created by Mrzou on 2018/3/11. */ //实现简单的订阅与发布模式的代码块export function pattern() { let currentLis ...

  3. 下一代 Android

    据闻,Android M 是下一代 Android 的开发代号.那么,对于 M,Google 正在实验着什么? 指纹识别 根据此前的消息,Nexus 6 据称原本是包含指纹识别传感器的,但后来在开发过 ...

  4. 【BZOJ3436】小K的农场(差分约束)

    [BZOJ3436]小K的农场(差分约束) 题面 由于BZOJ巨慢无比,使用洛谷美滋滋 题解 傻逼差分约束题, 您要是不知道什么是差分约束 您就可以按下\(Ctrl+W\)了 #include< ...

  5. luoguP2711 小行星

    题目描述 星云中有n颗行星,每颗行星的位置是(x,y,z).每次可以消除一个面(即x,y或z坐标相等)的行星,但是由于时间有限,求消除这些行星的最少次数. 输入输出格式 输入格式: 第1行为小行星个数 ...

  6. [BZOJ1005] [HNOI2008] 明明的烦恼 (prufer编码)

    Description 自从明明学了树的结构,就对奇怪的树产生了兴趣......给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树? Input 第一行为N ...

  7. [BZOJ1045] [HAOI2008] 糖果传递 (贪心)

    Description 有n个小朋友坐成一圈,每人有ai个糖果.每人只能给左右两人传递糖果.每人每次传递一个糖果代价为1. Input 第一行一个正整数n<=,表示小朋友的个数.接下来n行,每行 ...

  8. c# ffmpeg视频转换【转载】

    c#  ffmpeg视频转换 什么是ffmpeg,它有什么作用呢,怎么可以使用它呢,带着问题去找答案吧!先参考百度百科把,我觉得它很强大无奇不有,为了方便大家我就把链接提供了! http://baik ...

  9. UML那些事

    什么是UML?它的全名:Unified Modeling Language,统一建模语言.最近我用到了uml,顺便重温了下这些知识.知乎上有一个讨论话题:uml还有用吗?这个讨论挺有意思的,看完后,受 ...

  10. 洛谷 P1564 膜拜

    题目出处 s[i]表示前i个人对神牛的膜拜情况,如果膜拜神牛甲则s[i]=s[i-1]+1否则s[i]=s[i-1]-1.那么如果|s[i]-s[j]|<=m或者=i-j+1(也就是人数差不超过 ...