题目6-1 计算两数的和与差##

1.设计思路

(1)主要描述题目算法

第一步:看主函数知道程序输入浮点型变量a,b,通过函数计算输出和与差。

第二步:函数部分将a赋值op1,b赋值op2,&sum赋值到指针变量psum,&diff赋值到指针变量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, fracpart;整形变量intpart。输入x并通过调用函数splitfloat计算,之后输出结果。

第二步:x赋值给x,&intpart赋值给intpart, &fracpart赋值给fracpart。

第三步:将x强制转化为整型,用实数部分减去整数部分得到小数部分。

(2)流程图

主函数:

调用函数:

2.实验代码

void splitfloat( float x, int *intpart, float *fracpart )
{
*intpart=(int)x;
*fracpart=x-(int)x;
}

3.本题调试过程碰到问题及解决办法

题目6-1 在数组中查找指定元素##

1.设计思路

(1)主要描述题目算法

第一步:主函数定义整型变量i, index, n, x,a[10],输入n,for循环输入数组元素,输入待查元素x,通过函数search得到index值,若index不为-1,则输出index

的值,否则输出Not found;

第二步:定义指针变量p,整型变量i;p指向list[i];

第三步:通过for循环以及if判断语句观察数组中是否有x的值,若得到则将i返回,否则返回-1。

(2)流程图

主函数:

调用函数:

2.实验代码

int search( int list[], int n, int x )
{
int *p,i;
p=&list[i];
for(i=0;i<n;i++)
{
if(*p++==x)
return i;
}
return -1;
}

3.本题调试过程碰到问题及解决办法

使用指针变量时,在循环内应用*p++表示数组元素。

题目6-2 找最大值及其下标##

1.设计思路

(1)主要描述题目算法

第一步:定义N为10.主函数定义整型变量a[N],i,max,p=0;for循环输入数组元素,经过函数fun(a,&p,N)调用,得到最大值max及下标p的值;输出。

第二步:fun(a,&p,N)中的变量赋值给int fun(int a,int b,int n)中的变量;

第三步:先将首元素赋给max作为最大值,然后通过for循环一次比较,将最大的留下,并将下标赋给b。

(2)流程图

主函数:

调用函数:

2.实验代码

int fun(int *a,int *b,int n)
{
int i;
int max=*a;
for(i=1;i<N;i++)
{
if(*(a+i)>*a)
{
*b=i;
max=*(a+i);
}
}
return max;
}

3.本题调试过程碰到问题及解决办法

6-1 最小数放前最大数放后##

1.设计思路

(1)主要描述题目算法

第一步:本题主要是通过调用三个函数之后得到并输出结果。第一个和第三个函数运用for循环输入和输出。

第二步:第二个函数最主要。分为两部分,先用for循环将所有元素中的最大值和最小值找出,然后将最大值与第一个数交换,最小值与最后一个数交换即可。、

(2)流程图

主函数:

调用函数:

①input(int *arr,int n)

②max_min(int *arr,int n)

③output(int *arr,int n)



2.实验代码

void input(int *arr,int n)
{
int i;
for(i=0;i<n;i++)
{
scanf("%d",arr+i);
}
}
void max_min(int *arr,int n)
{
int i,max,min,t,p;
max=min=*arr;
for(i=0;i<n;i++)
{
if(max<*(arr+i))
{
max=*(arr+i);
t=i;
}
if(min>*(arr+i))
{
min=*(arr+i);
p=i;
}
}
int j;
j=*(arr+t);
*(arr+t)=*(arr+n-1);
*(arr+n-1)=j;
int k;
k=*(arr+p);
*(arr+p)=*arr;
*arr=k;
}
void output(int *arr,int n)
{
int i;
for(i=0;i<n;i++)
{
printf("%3d",*(arr+i));
}
}

3.本题调试过程碰到问题及解决办法

题目6-2 指针选择法排序##

1.设计思路

(1)主要描述题目算法

第一步:本题要调用一个选择排序法的函数,需要用到双循环结构。

第二步:调用函数第一层循环为趟数,第二层为比较大小,一次比较找出最值放到最前面。

(2)流程图

主函数:

调用函数:



2.实验代码

void sort(int *x,int n)
{
int i,j,t;
for(i=1;i<=n-1;i++)
{
for(j=0;j<=n-i-1;j++)
{
if(x[j]<x[j+1])
{
t=x[j];
x[j]=x[j+1];
x[j+1]=t;
}
}
}
}

3.本题调试过程碰到问题及解决办法

大括号较多导致后面缺少一个作结尾,编译错误。

仔细检查后发现错误并改正。

6-1 判断回文字符串##

1.设计思路

(1)主要描述题目算法

第一步:观察主函数,将数组元素输入之后通过调用palindrome判断字符串是否为回文字符串。最后输出。

第二步:通过strlen函数读取该数组的长度。

第三步:比较字符串中对称位置的字符是否相等,若有不相等的则返回值为false,若没有返回false,则palindrome函数返回值为true。

(2)流程图

主函数:

调用函数:

2.实验代码

bool palindrome( char *s )
{
int i;
int n = strlen(s);
for(i=0;i<=n/2;i++)
{
if(*(s+i)!=*(s+n-i-1))
return false;
}
return true;
}

3.本题调试过程碰到问题及解决办法

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

1.设计思路

(1)主要描述题目算法

第一步:主函数定义字符串t[MAXN], s[MAXN](MAXN=20),变量m。

第二步:引用函数strmcpy( char t, int m, char s )来实现字符串部分复制。输出。

(2)流程图

主函数:

调用函数:

2.实验代码

void strmcpy( char *t, int m, char *s )
{
int i;
for(i=m;*(t+i-1)!='\0';i++)
{
*(s+i-m)=*(t+i-1);
}
*(s+i-m)='\0';
}

3.本题调试过程碰到问题及解决办法

本题函数部分不知道怎么实现,通过同学讲解帮助完成。

附加题##

实验代码

#include<stdio.h>
int main()
{
char c;
while((c=getchar())!='\n')
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z'))
{
c=c+2;
if(c>'Z'&&c<='Z'+2||c>'z')
c=c-26;
}
printf("%c",c);
}
printf("\n");
return 0;
}

学习总结和进度##

1、总结两周里所学的知识点有哪些学会了?哪些还没有学会?

学会了指针在程序中的运用。了解到指针变量与之前所学的一些变量之间的运用。

还学到了统计字符串长度的方法(运用strlen函数)。

还没学到的或者说希望学到的是对指针变量更熟练地运用,目前还很生疏,应多多练习。

2、git地址: https://git.coding.net/ZJY15/ZJY15.git

上传:



3、点评:

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

丰大为 http://www.cnblogs.com/DavidPark/p/8551402.html

董雅洁 http://www.cnblogs.com/exo123/p/8575595.html

4、请用表格和折线图呈现你本周(3/12 8:00~3/26 8:00)的代码行数和所用时间、博客字数和所用时间

C语言-第一次作业的更多相关文章

  1. c语言第一次作业1

    第一次作业 一 你对软件工程或者计算机科学与技术专业的了解是什么? 软件工程是一门研究用工程化方法构建和维护有效的,实用的和高质量的软件的学科,涉及程序语言设计,数据库,软件开发工具,系统平台,设计模 ...

  2. 网络1712--c语言第一次作业总结

    1.作业亮点 1.1大家均能较为独立自主地完成第一次c语言作业,无明显抄袭现象 1.2 以下几位同学博文写的较为优秀,可作为范例供大家参考 田亚琴--态度端正,及时回复评论并及时完善修改博文 戴洁-- ...

  3. c语言------第一次作业,分支,顺序结构

    1.1思维导图 1.2本章学习体会及代码量学习体 1.2.1学习体会 初次接触C语言,由于比较懒惰,感觉学习脚步跟不上身边的同学,也比较困扰.但伴随着pta上多次显示的##编译错误##,坚持不懈地问舍 ...

  4. 网络1711班 C语言第一次作业批改总结

    Testing 总结 1 本次作业评分规则 1.1 基本要求(1分) 按时交 - 有分 未交 - 0分 迟交一周以上 - 倒扣本次作业分数 抄袭 - 0分 博客作业格式不规范,没有用Markdown语 ...

  5. c语言第一次作业——输入与输出格式

    一.PTA实验作业 1.温度转换 本题要求编写程序,计算华氏温度150°F对应的摄氏温度.计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型. 1.实验代码 ...

  6. C语言——第一次作业

    **学习内容总结** 本周进行了算法的初步学习,用计算机的思维方式去思考问题,并学习了如何用传统程序框图表示算法. 相关内容: 1.算法是用来解决问题的方法与步骤. 2.计算机擅长重复,常用枚举的方法 ...

  7. c语言第一次作业--分支 顺序结构

    1.1思维导图 1.2.1本周学习体会以及代码量学习体会 1.2.2学习体会 因为在假期时只看了小部分的学习视频,也没有刷题量,导致了在开始就感觉到差同学的进程很多.刚开始觉得老师讲课很快,在恶补了很 ...

  8. c语言第一次作业--顺序、分支结构

    1.1思维导图 1.2.1本周学习体会以及代码量学习体会 1.2.2学习体会     因为在暑假时候没有对c语言进行学习,没太关注一些学习资料,一些教学视频也没看,感觉对c语言是陌生的,刚开课的时候自 ...

  9. C语言第一次作业

  10. C语言第一次作业——输入输出格式

    题目1温度转换 本题要求编写程序,计算华氏温度150°F对应的摄氏温度.计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型. 1.实验代码 #include& ...

随机推荐

  1. div里面的图片垂直居中

    外面一个div, 里面是一张大小不固定的图片, 或者span,div都行, 要实现里面元素水平垂直居中对齐 其实有很多实现的方法, 比如用js去计算每一个子元素的高度, 通过js去动态设置magin值 ...

  2. 微信小程序—微信自动退款

    微信小程序—微信自动退款 一.业务背景 微信自动退款串接基于酷客多小程序商城系统,为方便财务人员进行订单退款而开发,将酷客多小程序系统财务退款流程和微信退款系统打通.实现一个系统管理运营. 二.业务流 ...

  3. Keras官方中文文档:keras后端Backend

    所属分类:Keras Keras后端 什么是"后端" Keras是一个模型级的库,提供了快速构建深度学习网络的模块.Keras并不处理如张量乘法.卷积等底层操作.这些操作依赖于某种 ...

  4. 【CJOJ P1365】最短路

    http://oj.changjun.com.cn/problem/detail/pid/1365 Description 给出N个点,M条无向边的简单图,问所有点对之间的最短路. Input 第1行 ...

  5. POJ1741

    树分治,每次把每个点的deep取出,排序...尺取法... # include <stdio.h> # include <stdlib.h> # include <ios ...

  6. 两种插入排序算法java实现

    两种方法都编译运行通过,可以当做排序类直接使用. 折半插入排序: public class Sort1 { public static void main(String[] args) { Inser ...

  7. Java关键字汇总

    Java共有51个关键字和2个保留字,保留字可能在后面的版本中成为新的关键字.关键字均为小写. 2个保留字: const:用于修改字段或局部变量的声明.它指定字段或局部变量的值是常数,不能被修改 go ...

  8. APNS IOS 消息推送沙盒模式和发布模式

    在做.NET向IOS设备的App进行消息推送时候,采用的是PushSharp开源类库进行消息的推送,而在开发过程中,采用的是测试版本的app,使用的是测试的p12证书采用的是ApnsConfigura ...

  9. codeforces 286E Ladies' Shop

    题目大意:n个小于等于m的数,现在你需要在[1,m]中选择若干个数,使得选出的数能组成的所有数正好与n个数相同,给出最少要选多少个数. 题目分析: 结论一:选择的若干个数一定在n个数中. 证明:否则的 ...

  10. mount挂载与umount卸载

    mount挂载与umount卸载 author:headsen chen      2017-10-23  15:13:51 个人原创,转载请注明作者,否则依法追究法律责任 mount:挂载: eg ...