第二学期-第一次作业

 

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/398439.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

一幅长文细学华为MRS大数据开发(三)——Hive

文章目录3 HIVE3.1 Hive概述Hive简介Hive应用场景Hive与传统数据仓库比较Hive优点3.2 Hive功能及架构Hive运行流程Hive数据存储模型Hive数据存储模型-分区和分桶Hive数据存储模型-托管表和外部表Hive支持的函数3.3 Hive基本操作Hive使用DDL操作DML操作DQL操作3 HIVE Apache Hi…

Huffman树进行编码和译码

//编码 #include<iostream> #include<cstdio> #include<cstring> #include<cstdlib> #include<algorithm> #include<queue> #include<fstream> #include<map> using namespace std;typedef struct HuffmanNode{int w;//节点…

更相减损法和辗转相除法(GCD)求最小公倍数和最大公约数

更相减损法和辗转相除法&#xff08;GCD&#xff09;求最小公倍数和最大公约数 标签&#xff08;空格分隔&#xff09;&#xff1a; 算法 算法竞赛 这两种算法平时经常听到&#xff0c;听起来也很装逼&#xff0c;但是我老是忘了他们的原理&#xff0c;今天好好想想&#xff0c…

一幅长文细学JavaScript(五)——ES6-ES11新特性

5 ES版本 摘要 ES5的先天不足致使ES后续版本的发展&#xff0c;这也是前端人员绕不开的一个点。如果我们想要在工作和面试中轻松解决问题&#xff0c;那么了解ES6-ES11是必不可少的。 在本文中&#xff0c;我将采用一种更加通俗的方式来讲述这一块知识点&#xff0c;而不是照搬…

Python自动化运维工具fabric的安装

使用shell命令进行复杂的运维时&#xff0c;代码往往变得复杂难懂&#xff0c;而使用python脚本语言来编写运维程序&#xff0c;就相当于开发普通的应用一样&#xff0c;所以维护和扩展都比较简单&#xff0c;更重要的是python运维工具fabric能自动登录其他服务器进行各种操作&…

项目开发一些注意事项

项目开发一些注意事项 1、一些简单的方法可以让你的代码看起来更明了&#xff0c;如函数或者方法&#xff0c;尽量的写的小一些&#xff0c;如果太冗长&#xff0c;尝试抽出一块写成一个函数&#xff1b;2、如果业务逻辑比较复杂&#xff0c;判断选项较多&#xff0c;可以把判断…

一幅长文细学Vue(一)——Webpack打包工具

1 项目开发工具 摘要 ​ 在本文中&#xff0c;我们会详细讨论webpack是如何打包发布项目&#xff0c;不过对于Vue来说&#xff0c;Vite可以做到和webpack一样的功能。 声明&#xff1a;如果想要看懂此文章&#xff0c;需具备node.js中npm的知识。 作者&#xff1a;来自ArimaMis…

I00005 打印直角三角形字符图案

曾经的计算机&#xff0c;没有显示屏&#xff0c;人们操作计算机时&#xff0c;用打印机记录执行的操作命令。 后来有了显示屏&#xff0c;不过最初的显示屏是字符频幕&#xff0c;输出只能是字符。 即使是今日&#xff0c;计算机已经进入多窗口图形界面时代&#xff0c;有时程…

由于不能随便改路径,所以写在这里

export LD_LIBRARY_PATH/usr/local/cuda-8.0/lib64:$LD_LIBRARY_PATHexport PATH/usr/local/cuda-8.0/bin:$PATH export LD_LIBRARY_PATH/root/anaconda2/envs/LTproto261/lib export PYTHONPATH/dev/LT/SegNet/caffe-segnet/python:$PYTHONPATH转载于:https://www.cnblogs.com…

动态数组使用

1 #include<stdio.h>2 #include<stdlib.h>3 4 int main()5 {6 int i;7 int n; //用于记录输入的整数的个数 8 int *p; //用于指向动态数组的存储空间 9 int sum0,average; //用于记录输入的整数的和与平均值 10 11 scanf("%d"…

一幅长文细学Vue(二)——Vue基础入门

2 Vue基础入门 摘要 ​ 在本文中&#xff0c;我们会快速地入门Vue。主要了解的是Vue各种指令语法。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码。 作者&#xff1a;来自ArimaMisaki创作 文章目录2 Vue基础入门2.1 概述2.1.1 Vue…

Linux下安装Redis及搭建主从

Linux下安装Redis 首先在官网下载对应版本的redis包&#xff0c;这里本人使用的是redis-4.0.8.tar.gz。然后在服务器中存放redis包的路径下执行tar –vxf redis-4.0.8.tar.gz&#xff08;这里对应下载的包&#xff09;&#xff0c;解压redis后,cd 进入 redis-4.0.8&#xff08;…

图解安装CentOS 6.6

以下是在虚拟机上安装CentOS 6.6的过程。一、安装文件:CentOS-6.6-x86_64-bin-DVD.iso二、安装步骤# 虚拟机的配置这里省略&#xff0c;在百度上有很多帖子可以参考。开启虚拟机进入安装界面&#xff0c;如下图所示选择第一个选项&#xff0c;按Enter安装程序加载完后&#xff…

phonegap安卓手机开发入门

先安装安卓开发安环境 http://www.cnblogs.com/zhangsanshi/p/3582368.html 安装phonegap 在安装ant http://www.cnblogs.com/yuzhongwusan/archive/2013/03/26/2982411.html 资源下载地址 http://pan.baidu.com/s/1mgHTNDm#path%252F 转载于:https://www.cnblogs.com/sung/p/4…

一幅长文细学Vue(三)——组件基础(上)

3 组件基础&#xff08;上&#xff09; 摘要 ​ 在本文中&#xff0c;我们将学习什么是SPA&#xff0c;以及Vue中组件的基本使用。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附上部分演示代码&#xff0c;main.js文件的代码通常不贴出&#xff…

综合练习:词频统计

下载一首英文的歌词或文章 将所有,.&#xff1f;&#xff01;’:等分隔符全部替换为空格 将所有大写转换为小写 生成单词列表 fopen(news.txt,r) newsf.read() f.close() sep,.!"?: for c in sep:newsnews.replace(c, )wordListnews.lower().split()for w in wordList:pr…

一幅长文细学Vue(四)——组件基础(下)

4 组件基础&#xff08;下&#xff09; 摘要 ​ 在本文中年我们会了解什么是props&#xff0c;怎么利用props在父组件和子组件之间传递数据&#xff1b;什么是计算属性&#xff0c;还有什么是事件。 声明&#xff1a;为了文章的清爽性&#xff0c;在文章内部的代码演示中只会附…

linux中fcntl()、lockf、flock的区别

fcntl()、lockf、flock的区别 ——lvyilong316 这三个函数的作用都是给文件加锁&#xff0c;那它们有什么区别呢&#xff1f;首先flock和fcntl是系统调用&#xff0c;而lockf是库函数。lockf实际上是fcntl的封装&#xff0c;所以lockf和fcntl的底层实现是一样的&#xff0c;对文…

获取.properties后缀的数据

在MyPro.properties中的数据如下&#xff1a; NameABC 测试类中&#xff1a; Properties properties new Properties(); String configFile "MyPro.properties"; //将MyPro.properties文件编译成文件流 InputStream is ConfigManager.class.getClassLoader().getR…

iOS开发拓展篇—音频处理(音乐播放器6)

一、图片处理 说明&#xff1a; Aspect表示按照原来的宽高比进行缩放。 Aspectfit表示按照原来的宽高比缩放&#xff0c;要求看到全部图片&#xff0c;后果是不能完全覆盖窗口&#xff0c;会留有空白。 Aspectfill表示按照原来的宽高比缩放&#xff0c;但只能看到部分图片。引发…