1-1. 计算两数的和与差

1.设计思路

第一步:设出被调用函数 op1, op2, *psum,  *pdiff ,利用被调函数计算*psum的值和*pdiff的值;

第二步:代入到主函数就是计算a、b的和与差;

第三部:对所得到数值进行输出;

2.流程图

3.插入代码

1 void sum_diff( float op1, float op2, float *psum, float *pdiff )
2 {
3   *psum = op1 + op2;
4   *pdiff = op1 - op2;
5 }

4.本题调试中遇到的问题:

本题未遇到问题;

1-2. 拆分实数的整数与小数部分

1.设计思路

第一步:根据主函数,设出被调用函数x, *intpart, *fracpart ,计算出*intpart的值、*fracpart的值;

第二步:主函数中输入函数x、fracpart,并且输入x的值,利用被调函数得出intpart和fracpart的值;

第三步:对所得到数值进行输出;

2.流程图

3.插入代码

1 void splitfloat( float x, int *intpart, float *fracpart )
2 {
3   *intpart = (int)x;
4   *fracpart = x - *intpart;
5 }

4.本题调试中遇到的问题

本题未遇到问题。

C高级第一次PTA作业(2)

2-1 .在数组中查找指定元素

1.设计思路

第一步:利用主调函数设出被调函数list[],  n, x,定义i、index、n、x为整形,输入n;

第二步:利用for循环输入a[i],调用被调函数确定index的值;

第三步:被调函数中,设j、q,为整形,利用for循环,寻找是否有x = list[j],如果有,则使q = j,如果没有,则q= -1;

第四步:利用if条件句,输出结果;

2.流程图

3.插入代码

 1     int search( int list[], int n, int x )
 2     {
 3         int j,q=-1;
 4         for(j=0;j<n;j++)
 5         {
 6             if(x==list[j])
 7             {
 8             q=j;
 9             break;
10             }
11         }
12         return(q);
13     }

4.本题调试中遇到的问题

break的位置,总是记错,多加练习即可。

2-2 .找最大值及其下标

1.设计思路

第一步:N =10,根据主调函数写出被调函数*a、*b、n,设q和j、q=a[0];

第二步:利用for循环查出是否有q < a[j],如果有,则把a[i]的值赋给q,j的地址赋给b;

第三步:另a[N]、i、max、p为整形,设p = 0;利用for循环输入a[i]的值,根据被调用函数比较出a、&p、N的最大值;

第四步:输出所得的最大值和p的值。

2.流程图

3.插入代码

 1 int fun(int *a,int *b,int n)
 2 {
 3         int q = a[0];
 4         int j;
 5         for(j=0;j<n;j++)
 6         {
 7             if(q < a[j])
 8             {
 9                 q = a[j];
10                 *b = j;
11             }
12         }
13         return(q);
14     }

4.本题调试中遇到的问题

*b,*a的表示还是有些不明白的地方,熟读笔记即可。

C高级第一次PTA作业(3)

3-1 .最小数放前最大数放后

1.设计思路

最重要的是被调函数的填写

第一步: 设出三个被调用函数,input(int*arr,int n)函数输入n个元素到arr中。

另i为整形,利用for循环在a[i]中输入10个新的元素。

第二步:max_min(int *arr, int n)函数求指针arr所指向的一维数组中的最大值和最小值,其中最小的数与第一个数对换,将最大的数与最后一个数对换。

设最小的元素和最大的元素都为a[0],令 i,temp,int ,q,w为整形,其中q= 0,w = 0;利用for循环把最大值和最小值进行赋值,q, w分别为最小值和最大                 值的下标。把所查找出的最大的下标与为加入数据前最大的数进行交换,把a[w]与a[rr+n-1]交换,同理,把a[p]与a[arr+0]作交换。

第三步:output(int*arr,int n)在一行中输出数组元素,每个元素输出占3列。使i为整形,利用for循环输出a[arr+i]的值。

2.流程图

主函数                                                           input函数                                                                output函数

 

max_min函数

3.插入代码

 1 void input(int *arr,int n)
 2 {
 3         int i;
 4         for(i=0;i<n;i++)
 5         {
 6             scanf("%d",arr+i);
 7         }
 8     }
 9     void max_min(int *arr,int n)
10
11     {
12         int min=arr[0],max=arr[0];
13         int i,temp;
14         int q=0,w=0;
15         for(i=0;i<n;i++)
16         {
17             if(min>*(arr+i))
18
19             {
20                 min=*(arr+i);
21                 q=i;
22             }
23             if(max<*(arr+i))
24             {
25                 max=*(arr+i);
26                 w=i;
27             }
28         }
29         temp=*(arr+0);*(arr+0)=*(arr+q);*(arr+q)=temp;
30         temp=*(arr+n-1);*(arr+n-1)=*(arr+w);*(arr+w)=temp;
31     }
32     void output(int *arr,int n){
33         int i;
34         for(i=0;i<n;i++){
35             printf("%3d",*(arr+i));
36         }
37     }

4.本题遇到的问题

input函数中,输入的‘arr+i’,写成了*arr +i,改过来即可。

3-2.指针选择法排序

1.设计思路

第一步:根据主函数设计被调用函数,*x, n,令*p、i、a[10]为整形,p = a;

第二步:被调用函数中,令i,j,s,temp为整形,若s=i,利用for循环比较*(x+s),*(x+j)的大小,如果*(x+s)<*(x+j),则把j的值赋给s;

若s不等于i,则交换*(x+i)和*(x+s)的值。

第三步:两次循环,第一次循环次数,第二次比较大小,进行被调函数的过程比较;

第四步:输出。

2.流程图

3.插入代码

 1     void sort(int *x,int n)
 2     {
 3          int i,j,s,temp;
 4          for(i=0;i<n-1;i++)
 5          {
 6              s=i;
 7              for(j=i+1;j<n;j++)
 8              {
 9                  if(*(x+s)<*(x+j))
10                  {
11                      s=j;
12                  }
13              }
14              if(s!=i){
15                  temp=*(x+i);*(x+i)=*(x+s);*(x+s)=temp;
16              }
17          }
18      }

C高级第一次PTA作业(4)

4.-1判断回文字符串

1.设计思路

第一步:根据主函数写出被调用函数,设MAXN为20,调用被调函数;

第二步:使i,count,q为整形,且count =0;count = strlen(s) ;    q=count / 2 ;利用for循环,比较(*(s+i))!=(*(s+count-i-1))是否正确,正确返回                        true,错误返回false;

第三步:验证是否与答案一致,输出‘yes‘或者‘no’。

第四步:输出s的值。

2.流程图

3.插入代码

 1     bool palindrome( char *s )
 2     {
 3         int i,count=0,q;
 4         count=strlen(s);
 5         q=count/2;
 6         for(i=0;i<q;i++)
 7         {
 8             if((*(s+i))!=(*(s+count-i-1)))
 9             {
10                 return(false);
11             }
12         }
13         if(i==q)
14         {
15             return(true);
16         }
17     }

4.本题调试遇到的问题

被调函数中,for循环语句,有些弄不明白。

4-2 使用函数实现字符串部分复制

1.设计思路

第一步:使MAXN为20,根据函数写出被调函数,新建数组t[MAXN], s[MAXN],使m为整形。

第二步:设被调用函数 *t,  m,*s ,设整形i,遍历数组;

第三步:输出结果。

2.流程图

3.插入代码

 1 void strmcpy( char *t, int m, char *s )
 2 {
 3       int i;
 4         for(i=m;*(t+i-1)!='\0';i++)
 5         {
 6           *(s+i-m)=*(t+i-1);
 7         }
 8
 9         *(s+i-m)='\0';
10
11
12 }

4.本题调试中遇到的问题

遍历的时候,不知道for循环语句下面怎么写,没有头绪。

 三。两周里所学的知识点有哪些学会了?哪些还没有学会?

1.

这两周学习的知识很多,第一周的时候,老师上课复习,所问的知识就有很多,我认为自己冒泡排序法有很多不懂的地方,连带现在所学的指针排序法也很不明白。全局变量也有一点的不懂,感觉还是很模糊。

所学的指针,指针的定义,指针的表示方法,定义规则,还有很多需要注意的地方,数组的遍历,还是有很多不懂的地方,比如,for循环语句知道了要怎样去写,但是下面该怎样写就完全没有头绪了。字符指针,中的替换,while语句,这些我个人感觉掌握的还好,虽然有些不明白的地方,但是还是可以学习下去。

2.PTA作业的源代码使用git提交到托管平台

截图

git地址

https://git.coding.net/smj031915/dexqdyczy.git

3.点评作业

我邀请点评作业的人(我点评的人)

张心悦:http://www.cnblogs.com/zxy980612/p/8641661.html

王姝雯:http://www.cnblogs.com/phsudie/p/8590614.html

吴晓明:http://www.cnblogs.com/gu-an-cheng-wxm/p/8597592.html

4.进度表

折线图

转载于:https://www.cnblogs.com/sun031915/p/8644175.html

第二学期-第一次作业相关推荐

  1. 信号与系统 2022 春季学期第一次作业-作业题目准备

    简 介: 关于作业的参考答案需要根据之前结果,再结合现在的修改进行补充. 关键词: 作业,信号与系统 #mermaid-svg-HSmAT7ir1Kl95O1z {font-family:" ...

  2. 华理c语言设计网上作业,华东理工大学第一学年第二学期网上作业参考答案C语言设计1...

    华东理工大学第一学年第二学期网上作业参考答案 考生答题情况 作业名称:2012年春季C语言设计(专)课程网上作业1 出 卷 人:SA 题号:1 题型:单选题(请在以下几个选项中选择唯一正确答案) 本题 ...

  3. 宣传部第二学期第一次培训

    宣传部第二学期第一次培训总结 一.网页基础HTML部分 1.什么是网页 网页是一种可以在互联网上传输,能被浏览器认识和翻译成页面并显示出来的文件,是网站的基本构成元素. 2.网页的类型 静态网页和动态 ...

  4. 天地人大湖北版2004-2005学年度第二学期第一次版聚总结

    谨以此文献给为本次版聚操劳奔走与热心参与的老乡们 五一前的这个周末,总是让人感到有点人心浮动.漫天的杨絮还未消沉,不温不火的风沙已欲起.趁着老天爷喘口气儿放晴的档儿,天地人大湖北版举行了2004-20 ...

  5. 铃铛子简笔画训练营第二期+第一次作业

    上周脑袋一热,感觉自己平时没什么兴趣爱好,然后又看了一大段鸡汤文,然后一冲动,就报了简笔画训练营.... 没上课之前,以为会很简单,说不定我是绘画天才,以后出去,刷刷几下,画出来一个美女: 上了课之后 ...

  6. 应用数据分析第二课第一次作业——创建一个数值范围为0~1,间隔为0.01的数组

    1.创建一个数值范围为0~1,间隔为0.01的数组 2.创建100个服从正态分布的随机数 3.对创建的两个数组进行四则运算 4.对创建的随机数组进行简单的统计分析 import numpy as np ...

  7. 微型计算机生产制约因素,精品解析:广东省东莞市2019-2020学年高三下学期第一次统考(5月)模拟考试文科综合地理试题...

    ID:15018200 资源大小:3271KB 资料简介: " \r东莞市2020届高三第二学期第一次统考(5月)模拟考试文科综合地理试题\r一.选择题\r下表为我国四个省市2009年.20 ...

  8. 2021年春季学期-信号与系统-第一次作业参考答案-第二题

      本文是: 2021年春季学期-信号与系统-第一次作业参考答案 的参考答案. ▌第二题: 写出下图所示的各波形的函数表达式: 第一小题: 求解: 这个函数可以使用分段函数来表示: 可以利用∣t∣\l ...

  9. 2021年春季学期-信号与系统-第一次作业参考答案-第六题

      本文是: 2021年春季学期-信号与系统-第一次作业参考答案 的参考答案. ▌第六题 MATLAB实验题1 请从网络学堂上下载音频信号,使用MATLAB软件绘制出它的视频联合分布图,分析其中电话号 ...

最新文章

  1. mysql数据库核对_Mysql数据库操作总结
  2. php安装libpng,php安装
  3. [8086汇编]利用栈翻转内存数据
  4. rabbitmq 查看消费者_RabbitMQ 和 Kafka 的比较
  5. C#中的StreamReader/StreamWriter
  6. LinkedList 源码小解
  7. python网址编码转换_python字符串与url编码的转换实例
  8. linux ubuntu/centos git 客户端编译安装升级
  9. 服务器 IIS主机的Rewrite伪静态组件下载与配置
  10. python飞机大战源码以及素材资源
  11. cad计算机试题及答案,CAD与CAM试题及答案.doc
  12. Java-mail发送邮件
  13. Elasticsearch(二):进阶检索
  14. 资料:基于MPSOC XCZU15EG-2FFVB1156I 的PCIe FMC 光纤接口处理卡设计资料保存
  15. NLP+词法系列(一)︱中文分词技术小结、几大分词引擎的介绍与比较
  16. 狄利克雷分布公式_潜在狄利克雷分配(LDA)
  17. dfs根目录_分布式文件系统DFS详细解读
  18. Docker容器指定映射端口启动redis
  19. 世唐科技:秒懂什么是区块链
  20. xb8886a规格书_拆解报告:Baseus倍思Bipow 10000mAh USB PD快充移动电源N1PD

热门文章

  1. [转载]linux内存映射mmap原理分析
  2. java基础之匿名内部类
  3. MyBatis入门(二)---一对一,一对多
  4. VS插件的开发 - Visual Studio Addin
  5. IE8无法调试?IE进入不了调试状态
  6. JavaScript-基础入门.0014.JavaScript内置对象
  7. OnLongClickListener长按事件设置墙纸
  8. DHT(Distributed Hash Table,分布式哈希表)
  9. orapwd创建密码文件
  10. pyramid新建项目