• C语言-第一次作业


    题目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)!='';i++)
        {
            *(s+i-m)=*(t+i-1);
        }
        *(s+i-m)='';
    }
    

    3.本题调试过程碰到问题及解决办法
    本题函数部分不知道怎么实现,通过同学讲解帮助完成。

    附加题##

    实验代码

    #include<stdio.h>
    int main()
    {
    	char c;
    	while((c=getchar())!='
    ')
    	{
    		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("
    ");
    	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)的代码行数和所用时间、博客字数和所用时间

  • 相关阅读:
    剑指offer 找出数组中重复的数字
    SE知识整理——泛型
    Centos7 切换与安装图形界面
    laravel8 elasticsearch 配置搭建使用
    ts运行配置.md
    ts类型保护
    2022年4月工作资料
    Cmake使用
    关于线性筛的研究
    SkyWalking在.NET平台的简单使用
  • 原文地址:https://www.cnblogs.com/17-1/p/8644191.html
Copyright © 2020-2023  润新知