• 第八章实验报告


    C程序设计实验报告

    实验项目:函数和宏定义实验

    姓名:罗子健 实验地点:物联网实验室 实验时间:2019年6月12日

    一、实验目的与要求

    (1)掌握指针的概念和定义方法。

    (2)掌握指针的操作符和指针的运算。

    (3)掌握指针与数组的关系。

    (4)掌握指针与字符串的关系。

    (5)熟悉指针作为函数的参数以及返回指针的函数。

    (6)了解函数指针。

    二、实验内容

    8.3.1 指针基础及指针运算

    1、问题的简单描述:

    (1)定义一个整形指针变量p,使它指向一个整形变量a,定义一个浮点型指针q,使它指向一个浮点型变量b,同时定义另外一个整形变量c并赋初值3。
    (2)使用指针变量,调用scanf函数分别输入a和b的值。
    (3)通过指针间接访问并输出a,b的值。
    (4)按十六进制方式输出p,q的值以及a,b的地址。
    (5)将p指向c,通过p间接访问c的值并输出。
    (6)输出p的值及c的地址,并与上面的结果进行比较。

    2、实验代码和结果:

     1 /* 8_1.c */ 
     2 #include <stdio.h>
     3 int main()
     4 {
     5     int *p,a,c=3;
     6     float *q,b;
     7     p=&a;
     8     q=&b;
     9     printf("Please Input the Value of a,b:");
    10     scanf("%d%f",p,q);        /*使用指针p和q输入a,b的值*/ 
    11     printf("Result:
    ");
    12     printf("     %d,%f
    ",a,b);
    13     printf("     %d,%f
    ",*p,*q);    /*通过指针p和q间接输出a,b的值*/ 
    14     printf("The Address of a,b:%p,%p
    ",&a,&b);
    15     printf("The Address of a,b:%p,%p
    ",p,q);    /*输出p和q的值并与上行输出结果进行比较*/ 
    16     p=&c;
    17     printf("c=%d
    ",*p);
    18     printf("The Address of c:%x,%x
    ",p,&c);    /*输出p的值以及c的地址*/ 
    19     return 0;
    20  } 

    3、问题分析:无。

    8.3.2 数据交换

    1、问题的简单描述:

    (1)定义两个函数,分别为void swap(int a,int b)和void swap2(inta,int b),用于交换a,b的值。
    (2)从主函数中分别输入两个整形变量a,b。
    (3)从主函数中分别调用上述两个交换函数,并打印输出交换后a,b的结果。

    2、实验代码和结果:

     1 /* 8_2.c */
     2 #include<stdio.h>
     3 void swap1(int x,int y);
     4 void swap2(int*x,int*y);
     5 int main()
     6 {
     7     int a,b;
     8     printf("Please Input a=:");
     9     scanf("%d",&a);
    10     printf("
                 b=:");
    11     scanf("%d",&b);
    12     swap1(a,b);
    13     printf("
    After Call swap1:a=%d b=%d
    ",a,b);
    14     swap2(&a,&b);                            /*实参传递*/ 
    15     printf("
    After Call swap2:a=%d b=%d
    ",a,b);
    16     return 0; 
    17 }
    18 void swap1(int x,int y)
    19 {
    20     int temp;
    21     temp=x;
    22     x=y;
    23     y=temp;
    24 }
    25 void swap2(int *x,int *y)
    26 {
    27     int temp;
    28     temp=*x;
    29     *x=*y;
    30     *y=temp;/*交换x,y地址上的值*/ 
    31 }

    3、问题分析:利用值的交换。

    8.3.3 字符串反转及字符串连接

    1、问题的简单描述:

    (1)定义两个字符指针,通过gets()函数输入两个字符串。
    (2)定义一个函数char reverse(charstr),通过指针。
    (3)定义一个函数char link(charstr1,char*str2),通过指针移动方式将两个字符串连接起来。
    (4)从主函数中分别调用上述函数,输入字符串并打印输出结果。

    2、实验代码和结果:

     1 #include<stdio.h>
     2 char *reverse(char *str);
     3 char *link(char *str1,char *str2);
     4 int main()
     5 {
     6     char str[30],str1[30],*str2;    
     7     printf("Input Reversing Character String: ");
     8     gets(str);
     9     str2=reverse(str);
    10     printf("
    Output Reversed Character String: ");
    11     puts(str2);
    12     printf("Input String1: ");
    13     gets(str);
    14     printf("
    Input String2: ");
    15     gets(str1);
    16     str2=link(str,str1);
    17     printf("
    Link String1 and String2: ");
    18     puts(str2);
    19     return 0;
    20 }
    21 char *reverse(char *str)
    22 {
    23     char *p,*q,temp;
    24     p=str;q=str;
    25     while(*p!='')    /*判断是否到达最后一个字符*/ 
    26         p++;
    27     p--;
    28     while(q<p)
    29     {
    30         temp=*q;
    31         *q=*p;
    32         *p=temp;
    33         q++;p--;    /*指针做相向移动处理*/ 
    34     }     
    35     return str;     /*返回结果*/ 
    36  } 
    37  char *link(char *str1,char *str2)
    38  {
    39     char *p=str1,*q=str2;
    40     while (*p!='')
    41         p++;
    42     while(*q!='')
    43     {
    44         *p=*q;/*q指向的元素赋值到p所指向的元素*/ 
    45         p++;
    46         q++;    /*指针做相应的移动处理*/ 
    47     }
    48     *p='';    /*令结束字符为空字符*/ 
    49     return str1;
    50 }

    3、问题分析:要让指针进行相向处理,经过值的交换后,改变指针的位置。

    8.3.4 数组元素奇偶排列

    1、问题的简单描述:

    (1)定义一个整形一维数组,任意输入数组的元素,其中包含奇数和偶数。
    (2)定义一个函数,实现将数组元素奇数在左,偶数在右的排列。
    (3)在上诉定义的函数中,不允许再增加新的数组。
    (4)从主函数中分别调用上述函数,打印输出结果。

    2、实验代码和结果:

     1 /*sy8_3_4.c*/ 
     2 #include <stdio.h>
     3 #define N 10
     4 void arrsort(int a[],int n);
     5 int main()
     6 {
     7     int a[N],i;
     8     for(i=0;i<N;i++)
     9        scanf("%d",&a[i]);
    10     arrsort(a,N);
    11     for(i=0;i<N;i++)
    12     printf("%d ",a[i]);
    13 }  
    14 void arrsort(int a[],int n)
    15 {
    16     int *p,*q,temp;
    17     p=a;
    18     q=a+n-1;
    19     while(p<q)
    20     {
    21         while(*p%2==1)    /*判断*p是否为奇数*/ 
    22            p++;            /*指针向后移动*/ 
    23         while(*q%2==0)    /*判断*q是否为偶数*/ 
    24            q--;            /*指针向前移动*/ 
    25         if(p>q)
    26         break;
    27         temp=*p;
    28         *p=*q;
    29         *q=temp;
    30         p++;q--;        /*指针相向移动*/ 
    31     }
    32 }

    3、问题分析:需要利用除余来判定是奇数还是偶数。

    三、实验小结(在本次实验中收获与不足)

    熟悉了指针的使用方法,虽然还有许多地方不够熟练,但多去实践,就会熟能生巧的。

  • 相关阅读:
    qt5--创建控件的两种方式
    qt5-编码转换
    C++qt助手assistant
    C++opencv绘制几何图形
    C++opencv创建图像
    【全球软件大会】华为前端工程师分享:华为云官网的智能化实践
    图解 Redis丨这就是 RDB 快照,能记录实际数据的
    云小课 | 玩转HiLens Studio之快速订购HiLens Studio版本
    带你认识4种设计模式:代理模式、装饰模式、外观模式和享元模式
    线性表、顺序表和链表,你还分不清?
  • 原文地址:https://www.cnblogs.com/gnxyxlzj/p/11021749.html
Copyright © 2020-2023  润新知