zoukankan      html  css  js  c++  java
  • 第八章 指针

    C程序设计实验报告

    实验项目:

    <1>8.3.1 指针基础及指针运算
    <2>8.3.2 数据交换
    <3>8.3.3 字符串反转及字符串连接
    <4>8.3.4 数组元素奇偶排列

    姓名:石益涛  实验地点:教学楼514教室  实验时间:2019.6.12

    一、实验目的与要求

    <1>掌握指针的概念和定义方法。

    <2>掌握指针的操作符和指针的运算。

    <3>掌握指针与数组的关系。

    <4>掌握指针与字符串的关系。

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

    <6>了解函数指针。

    二、实验内容

    实验练习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.实验代码:

    /*8-1.c*/
    # include <stdio.h>
    int main()
    {
        int *p,a,c=3;
        float *q,b;
        p=&a;
        q=&b;
        printf("Please Input the value of a,b:");
        scanf("%d%f",p,q);      
    printf(
    "Result: "); printf(" %d, %f ",a,b); printf(" %d, %f ",*p,*q);
    printf("The Address of a,b: %p,%p ", &a, &b); printf("The Address of a,b:%p,%p ", p, q);
    p=&c; printf("c=%d ", *p) ; printf("The Address of c: %x, %x ", p, &c);
    }

    3.运行结果:

    4.问题分析:

    实验练习2: 数据交换

    1.问题的简单描述:
    (1)定义两个函数,分别为voidswap1(inta,intb)和voidswap2(inta,intb),用于交换a,b的值。
    (2)从主函数中分别输入两个整型变量a、b。
    (3)从主函数中分别调用上述两个交换函数,并打印输出交换后a、b的结果。
    2.实验代码:

    # include <stdio.h>
    void swap1 (int x, int y);
    void swap2 (int *x, int *y);
    int main()
    {
        int a,b;
        printf("Please Input a=:");
        scanf("%d", &a);
        printf("
            b=:");
        scanf("%d", &b);
        swap1(a,b);
        printf("
    After Call swap1: a=%d b=%d
    ",a,b);
        swap2(&a,&b);           
        printf("
    After Call swap2: a=%d b=%d
    ",a,b);
        return 0;
    }
    void swap1(int x, int y)
    {
        int temp;
        temp=x;
        x=y;
        y=temp;
    }
    
    void swap2(int *x, int *y)
    {
        int temp;
        temp=*x;
        *x=*y;
        *y=temp;    
    }

    3.运行结果:

    4.问题分析:

    仅仅是填书上需要填的空,没有问题

    实验练习3:字符串反转及字符串连接

    1.问题的简单描述:
    (1)定义两个字符指针,通过gets()函数输入两个字符串。
    (2)定义一个函数char reverse(char str),通过指针移动方式将字符串反转。
    (3)定义一个函数char link(char str1, char *str2),通过指针移动方式将两个字符串连接起来。
    (4)从主函数中分别调用上述函数,输入字符串并打印输出结果。
    2.实验代码:

    # include <stdio.h>
    char *reverse (char *str);
    char *link (char *str1, char *str2);
    int main()
    {
        char str[30], str1[30], *str2;
        printf("Input Reversing Character String: ");
        gets (str);
        str2=reverse (str);
        printf("
    Output Reversed Character String: ");
        puts (str2);
        printf("Input String1: ");
        gets (str);
        printf("
    Input String2: ");
        gets (str1);
        str2=link(str, str1);
        printf("
    Link String1 and String2: ");
        puts (str2);
        return 0;
     } 
     
     char *reverse (char *str)
     {
        
        char *p, *q, temp;
        
        p=str, q=str;
        
        while (*p!='')    
             p++;
        p--;
        while (q<p)
        {
            temp=*q;
            *q=*p;
            *p=temp;
            q++;p--; 
        }
        return str;  
     }
     
     char *link (char *str1, char *str2)
     {
        char *p=str1, *q=str2;
        while (*p != '')
               p++;
        while (*q != '')
        {   
            *p=*q;   
            q++; 
            p++;  
        }
        putchar('');  
        return str1;
     }

    3.运行结果:

    4.问题分析:

    当q<p、指针做相向移动时,应该是“q++;p--”,我打的是“q--;p++”,后面都输出不了。

    实验练习4: 数组元素奇偶排列

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

    # include <stdio.h>
    # define N 10
    void arrsort (int a[], int n);
    int main()
    {
        int a[N], i;
        for (i=0;i < N;i++)
             scanf ("%d", &a[i]);
        arrsort (a, N);
        for (i=0;i< N;i++)
        printf("%d ", a[i]);
    }
    
    void arrsort (int a[], int n)
    {
        int *p, *q, temp;
        p=a;
        q=a+n-1;
        while (p<q){
            while (*p%2!=0)   
                  p++;        
            while (*q%2==0)   
                  q--;        
            if (p>q)
                break; 
            temp=*p;
            *p=*q;
            *q=temp;
            p++;q--;    
        }
    }

    3.运行结果:

    4.问题分析:
    这个题目没有很复杂,只需要知道判断奇数和偶数,将奇数往前移,偶数往后移就可以

    三、实验小结

    1.可以通过指针间接访问并输出变量的值;
    2.将实参传给形参时有两种方式:值传递与址传递;
    3.使用指针作为形参时,实参必须是地址或数组名;

  • 相关阅读:
    图的深度优先搜索(递归和非递归c++实现)
    第十届蓝桥杯大赛软件类省赛 迷宫问题题解
    第十届蓝桥杯大赛软件类省赛研究生组 试题D:最短路
    第十届蓝桥杯大赛软件类省赛研究生组 试题H:修改数组
    Redis设计与实现书中勘误-sdstrim函数解释错误
    Clion 引入libevent Undefined symbols for architecture x86_64: "
    RabbitMQ Linux 下 安装
    kafka基本使用
    2种方法改变String 值
    Maven学习笔记-1
  • 原文地址:https://www.cnblogs.com/sytsytsyt/p/11032097.html
Copyright © 2011-2022 走看看