C语言学习(6)

KilluaZoldyck 2020-03-09

一、C语言中的指针

1. 指针的基本概念

指针:

也是一种变量,是一种特殊的变量(专门用来存放其它变量在内存中地址的)

int a;

float b;

一个变量有多个字节(内存中有多个地址编码),指针存放的是这个变量的首地址(最低的地址,起始位置的地址)

指针的定义:

类型 *指针的名字

比如: int *p; //定义了int类型的指针 *表示p是个指针

float *q;

char *p;

指针的使用:

第一种: 定义一个指针并初始化

int a=10;

int *p=&a; // & -->取地址符号(获取变量a在内存中的首地址)

第二种: 定义一个指针没有立马初始化

int a=10;

int *p; //定义了指针p,p存放谁的地址目前是不清楚的

p=&a;

指针的几种基本运算

第一种: 解引用

通过指针访问指向的变量里面的内容,或者通过指针修改指向的变量

使用解引用运算

*p; //把指针p解引用(取出指针p指向的地址里面的内容)

第二种:取地址

int a=100;

int *p=&a; //对a取地址

  小结: 指针是C语言提供的一种间接访问变量的方法

第三种: 指针可以比较大小

指针比较大小---》就是把地址当成是数字来比较

#include <stdio.h>

int main()
{
    int a = 888;
    int *p = &a; //指针p指向a的首地址

    //打印一下变量a在内存中首地址
    printf("a的首地址是:%p\n", &a);
    printf("指针p中存放的地址是:%p\n", p);

    //指针的作用一: 通过指针访问它指向的地址中的数据内容
    printf("传统的方法访问a的值:%d\n", a);
    printf("通过指针访问a的值: %d\n", *p); //解引用p

    //指针的作用二: 通过指针修改变量的值
    *p = 666;
    printf("a被修改成了:%d\n", a);
}

练习:

1. int a[5]; //键盘输入5个数,用指针实现判断这个五个数是不是完数

完数: 一个数等于自身公因子和 (去除本身)

比如: 6 ---》公因子(能被6整除就是它的公因子) 1 2 3

6= 1+2+3

7 --》 公因子 1

int *p= &a[0] // *p等价于a[0]

//如何求*p公因子--> *p分别除以1 2 3 ....*p只要能整除的就是公因子

p=&a[1]

#include <stdio.h>

int main()
{
    int *p, i, j = 0, k;
    int flag = 0;
    int input[5] = {0};
    int temp = 0;
    int output[5] = {0};
    printf("请输入5个数:\n");
    for (i = 0; i < 5; i++)
        scanf("%d", &input[i]);

    for (i = 0; i < 5; i++)
    {
        p = &input[i]; //取地址
        for (k = 1; k < *p; k++)
        {
            flag = *p % k; //取余判断是否整除
            if (flag == 0) //整除为0
            {
                temp += k;      //将能够整除的k加起来
                if (temp == *p) //判断是否为完数
                {
                    output[j++] = *p; //使用数组保存起来
                }
            }
        }
        temp = 0; //使用完清空
    }

    printf("以上5个数是完数的是:\n");
    for (i = 0; i < j; i++)
    {
        printf("%d ", output[i]);
    }
    printf("\n");
    return 0;
}

作业:

1.基础题

输入字符串,分别统计出其中 英文字母、空格、数字和其它字符的个数。

求a+aa+aaa+aaaa+aa...a的值

比如:a是3,总共5项(变量n表示) 3+33+333+3333+33333结果是??

要求a和n从键盘输入

思路:3+33+333+3333+33333 ---》 3*(1+11+111+1111+11111)

#include <stdio.h>
#include <math.h> //因为引用10的n次方才调用pow(10,n)

int main()
{
    int i, temp = 0, sum = 0, input_1, input_2;

    printf("Please enter 2 numbers!\n");
    scanf("%d %d", &input_1, &input_2);

    for (i = 0; i < input_2; i++) //求和:1+11+111+...+i个1
    {
        temp += (int)pow(10, i); //这里调用了math.h中的pow函数,使用10的n次方
        sum += temp;             //1+11+111+…

        //思路为:Num[n]=Num[n-1]*10+1;
    }
    sum *= input_1; //将总和乘于第一个数
    printf("The final result is:%d\n", sum);
    return 0;
}

2.写一个程序处理字符串A,处理规则是: 只要字符串B里面有的字符,不论大小写,一律从A字符串中删除 (用数组或者指针实现)

fdjjfDFDdjfjdf ---》 A字符串

AFafd ---》 B字符串

#include <stdio.h>
#include <string.h>

int main()
{
    int i, j, k, len_1 = 0, len_2 = 0;
    char input_1[50], input_2[50];

    printf("Please enter 2 strings\n");
    scanf("%s %s", input_1, input_2);

    len_1 = strlen(input_1);
    len_2 = strlen(input_2);

    //先筛选调字符串B的重复字符
    for (i = 0; i <= len_2 - 1; i++)
    {
        for (j = i + 1; j <= len_2 - 1; j++)
        {
            if (input_2[i] == input_2[j])
            {

                for (k = j; k <= len_2 - 1; k++) //将这个字符丢掉,将后面的字符向前移动
                {
                    input_2[k] = input_2[k + 1];
                }
                len_2--; //字符长度减少
                j--;     //重新匹对
            }
        }
    }

    //字符串A逐个与经过处理的字符串B进行比较,若发现相同的,则剔除
    for (i = 0; i <= len_2 - 1; i++) //字符串B
    {
        for (j = 0; j <= len_1 - 1; j++) //字符串A
        {                                //判断字符串B中的字符是否等于字符串A中的字符,eg:a=a本身;a=A+32;A=a-32
            if ((input_2[i] == input_1[j] + 32) || (input_2[i] == input_1[j]) || (input_2[i] == input_1[j] - 32))
            {

                for (k = j; k <= len_1 - 1; k++) //将这个字符丢掉,将后面的字符向前移动
                {
                    input_1[k] = input_1[k + 1];
                }
                len_1--; //字符长度减少
                j--;     //重新匹对
            }
        }
    }

    printf("Removing duplicate characters:%s\n", input_1);
    return 0;
}

相关推荐