2018c语言第1次作业
6-1 计算两数的和与差
1.设计思路
(1)主要描述题目算法
第一步:把两个数的加减法分别赋给psum和pdiff。
第二步:通过psum和pdiff的地址把值传回主函数。
(2)流程图.(无)
2.实验代码
void sum_diff( float op1, float op2, float *psum, float *pdiff )
{
*psum = op1+op2;
*pdiff = op1-op2;
}
3.本题调试过程碰到问题及解决办法
无错误.
6-2 拆分实数的整数与小数部分
1.设计思路
(1)主要描述题目算法
第一步:通过强制转换类型把x定义成整数获得整数部分。
第二步:再把原来的x减去整数部分得到小数部分。
第三步:通过地址把值传回主函数。
(2)流程图(无)
2.实验代码
void splitfloat( float x, int *intpart, float *fracpart)
{
*intpart=(int)x;
*fracpart=x-*intpart;
}
3.本题调试过程碰到问题及解决办法
无问题.
6-3 在数组中查找指定元素
1.设计思路
(1)主要描述题目算法
第一步:先把-1赋值给t作初值。
第二步:用for循环语句和if语句找出对应数最小下标,赋值给t。
第三步:返回t。
(2)流程图


2.实验代码
int search( int list[], int n, int x )
{
int j=0,t=-1;
for(j=0;j<n;j++)
{
if(list[j]==x)
{
t=j;
break;
}
}
return t;
}
3.本题调试过程碰到问题及解决办法
错误原因:if语句中把x赋值给list[j]中。
改正方法:在if语句中多加一个等号。
6-4找最大值及其下标
1.设计思路
(1)主要描述题目算法
第一步:用for循环和if从句判断出最大值赋值给t。
第二步:利用指针把最小下标传给主函数。
第三步:返回t值。
(2)流程图


2.实验代码
int fun(int *a,int *b,int n)
{
int j=0,t=a[j];
for(j=0;j<10;j++)
{
if(a[j-1]<a[j])
{
t=a[j];
*b=j;
}
}
return t;
}
3.本题调试过程碰到问题及解决办法
(无).
6-最小数放前最大数放后
1.设计思路
(1)主要描述题目算法
第一步:利用for循环向数组输入数值。
第二步:利用for循环找出最大值最小值再进行交换。
第三步:根据格式输出数组。
(2)流程图




2.实验代码
void input(int *arr,int n)
{
int i=0,k=0;
for(i=0;i<n;i++)
{
scanf("%d",*(arr+k));
k++;
}
}
void max_min(int *arr,int n)
{
int i,t=0,o=0,c,b;
for(i=1;i<n;i++)
{
if(*(arr+i)<*(arr+o))
{
o=i;
}
}
for(i=1;i<n;i++)
{
if(*(arr+i)>*(arr+t))
{
t=i;
}
}
c=*arr;
*arr=*(arr+o);
*(arr+o)=c;
b=*(arr+n-1);
*(arr+n-1)=*(arr+t);
*(arr+t)=b;
}
void output(int *arr,int n)
{
int i;
for(i=0;i<n;i++)
printf("%3d",*(arr++));
}
3.本题调试过程碰到问题及解决办法
错误原因:输出的时候格式错误。
改正方法:输出时前面加上3d调整格式。
6-指针选择法排序
1.设计思路
(1)主要描述题目算法
第一步:定义j,i,t的初值为零。
第二步:用镶嵌for循环比大小调换数值。
(2)流程图


2.实验代码
void sort(int *x,int n)
{
int i=0,j=0,t=0;
for(j=0;j<n-1;j++)
{
for(i=j;i<n;i++)
{
if(*(x+i)>*(x+j))
{
t=*(x+i);
*(x+i)=*(x+j);
*(x+j)=t;
}
}
}
}
3.本题调试过程碰到问题及解决办法
(无)
6-1 判断回文字符串
1.设计思路
(1)主要描述题目算法
第一步:用strlen求出符号长度n。
第二步:for循环从左往右找两个符号不同 ,然后结束循环。
第三步:利用for做标记,返回t值。
(2)流程图


2.实验代码
bool palindrome( char *s )
{
int i,j,t;
int n=strlen(s);
for(i=0,j=n-1;i<j;i++,j--)
{
if(s[i]!=s[j])
{
break;
}
}
if(i>=j)
{
t=true;
}
else
{
t=false;
}
return t;
}
3.本题调试过程碰到问题及解决办法
错误原因:for循环的条件一开始出现错误。
改正方法:用编程软件调试改正。
6-2 使用函数实现字符串部分复制
1.设计思路
(1)主要描述题目算法
第一步:算出符号长度,if长度不够设为空串。
第二步:够长度,从第七个符号用for循环开始替换。
(2)流程图


2.实验代码
void strmcpy( char *t, int m, char *s )
{
int i,n,j;
for(n=0;;n++)
{
if(t[n]=='\0')
{
break;
}
}
if(m>n)
{
*s=NULL;
}
else
{
for(i=m-1,j=0;i<=n-1;i++)
{
s[j]=t[i];
j++;
}
s[j]='\0';
}
}
3.本题调试过程碰到问题及解决办法
错误原因:复制过去的字符答案不对。
改正方法:在字符里加上一个结束符。
1总结两周里所学的知识点有哪些学会了?哪些还没有学会?
我们这周学习了指针,数组和字符指针,指针一开始还还可以,后来字符指针就有点不太懂,不过通过做题慢慢的就理解了。
2、将PTA作业的源代码使用git提交到托管平台上,要求给出上传成功截图和你的git地址。请注意git地址应是类似
https://git.coding.net/yangzhiqun/cfsafa.git
点评3个同学的本周作业(在作业中给出被点评同学博客的链接),并邀请3名同学点评你的作业,无点评作业(你的作业未被3人点评)/或者没有回复同学或老师的点评都倒扣该题分数。
尧舜禹http://www.cnblogs.com/yaoshunyux/p/8641466.html
徐铭博http://www.cnblogs.com/xmb1547828350/p/8597402.html
于耀淞http://www.cnblogs.com/jsjyys/p/8589997.html
4、请用表格和折线图呈现你本周(3/12 8:00~3/26 8:00)的代码行数和时间、博客字数和时间(3分)。

2018c语言第1次作业的更多相关文章
- 2018C语言第三次作业
要求一 2.struct sk{int a; char *str)}*p; p->str++ 中的++ 加向? ++加向srt的地址. 要求二 题目1-计算平均成绩 1.设计思路 (1)主要 ...
- 2018c语言第3次作业
6-1 输出月份英文名 1.设计思路 (1)主要描述题目算法 第一步:先定义一个指针数组. 第二步:根据for循环判断月份并返还月份字数. 2.实验代码 int getindex( char *s ) ...
- 2018c语言第2次作业
1 删除字符串中数字字符 1.设计思路 (1)主要描述题目算法 第一步:先用for循环比较每个数是否符合删除条件. 第二步:如果符合就把这个数利用交换把这个数提前一位. 2.实验代码 void del ...
- 关于C语言的问卷调查(作业三)
1.你对自己的未来有什么规划?做了哪些准备? 答:我对我未来的规划就是希望能够学有所用,将来可以从事有关IT方面的,跟自己的专业对口.为此现在我需要多看一些和这个专业有关的书籍,自学一些知识,多些一些 ...
- 网络1711班 C语言第四次作业批改总结
网络1711班 C语言第四次作业批改总结 助教有话说(写在前面) 近来,有同学跟老师和助教们反映:博客作业太多太麻烦,而且对编程能力提高似乎没什么帮助?在这里我要谈一谈我的感想. 博客作业的意义? 首 ...
- 网络1711班 C语言第七次作业批改总结
网络1711班 C语言第七次作业批改总结 1.本次作业评分细则 1.1 基本要求(1分) 按时交 - 有分 未交 - 0分 迟交一周以上 - 倒扣本次作业分数 抄袭 - 0分 泛泛而谈(最多七分) 1 ...
- 网络1711班 C语言第八次作业批改总结
网络1711班 C语言第七次作业批改总结 最近在忙一些琐事,没能及时批改大家的作业,连续两次作业总结也没有很用心写,在这要给大家say sorry. 1.本次作业评分细则 1.1 基本要求(1分) 按 ...
- C语言程序设计第二次作业--顺序结构
C语言程序设计第二次作业--顺序结构 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 #include <stido ...
- 跨语言调用Hangfire定时作业服务
跨语言调用Hangfire定时作业服务 背景 Hangfire允许您以非常简单但可靠的方式执行后台定时任务的工作.内置对任务的可视化操作.非常方便. 但令人遗憾的是普遍都是业务代码和hagnfire服 ...
随机推荐
- 深度学习——卷积神经网络 的经典网络(LeNet-5、AlexNet、ZFNet、VGG-16、GoogLeNet、ResNet)
一.CNN卷积神经网络的经典网络综述 下面图片参照博客:http://blog.csdn.net/cyh_24/article/details/51440344 二.LeNet-5网络 输入尺寸:32 ...
- 在TextBox中敲击回车执行ASP.NET后台事件
1.在TextBox中敲击回车执行ASP.NET后台事件 0.说明 页面中有一个用于搜索的TextBox,希望能在输入内容后直接回车开始搜索,而不是手动去点击它旁边的搜索按钮 但因为该TextBo ...
- Latex基础__如何用latex编写矩阵、矩阵等式、方程组、等式左对齐
数学矩阵和方程组是数学工作者经常遇到的,那么如何用latex书写处漂亮的方程组.矩阵.多个等式呢,下面将对这个问题一一做介绍.1. 写矩阵. 代码: \begin{equation} \left[ \ ...
- Python中的栈溢出及解决办法
1.递归函数 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 举个例子,我们来计算阶乘n! = 1 x 2 x 3 x ... x n,用函数fact(n)表示, ...
- python数据类型——字典类型
字典(dictionary) python中唯一的映射类型,采用键值对(key-value)的形式储存数据,python对key进行哈希函数运算,所以key值必须是可哈希的,可哈希表示key必须是不可 ...
- 25.django Model
django ORM基本配置 django中遵循 Code Frist 的原则,即:根据代码中定义的类来自动生成数据库表 1.修改project数据库配置 (1)settigs.py里面 默认 DAT ...
- H5页面基于接口实现数据交互
对于现在APP开发来说,目前流行的两个方式是原生和H5.就如同之前业界程序猿争论的BS和CS之争一样,业界对于H5和原生也有不小的争论.对于前者的争论在于PC端,后者在于移动端上体现. 那一个APP适 ...
- Java虚拟机系列-Java类加载机制
原文:http://www.ityouknow.com/jvm/2017/08/19/class-loading-principle.html 一. 类加载: 1. 将.class文件的二进制数据加载 ...
- WordPress添加个性化的博客宠物的方法
在很多的网站上都看见过这种效果,于是自己也想试试.看见我网站上的小宠物了吗,就是这种效果. 不多说,方法如下: 工具: 下载地址:http://yunpan.cn/cFUmZB8WWthty 访问密码 ...
- JS如何判断滚动条是否滚到底部
判断滚动条到底部,需要用到DOM的三个属性值,即scrollTop.clientHeight.scrollHeight. scrollTop为滚动条在Y轴上的滚动距离. clientHeigh ...