C语言中指针的基础知识

简介: C语言中指针的基础知识

1、指针和变量的定义

//变量定义
int i,j,k;
//指针的定义
int *pi,*pj,*pk;

2、指针和变量的初始化

//变量定义
int i,j,k;
//指针的定义
int *pi,*pj,*pk;
//变量的初始化
i = 10;
j = 100;
k = 1000;
//指针的初始化
pi = &i;
pj = &j;
pk = &k;

如果你还不知道&和*的用法和作用,可以参考我这篇:

《C语言中的&和*》

3、指针如何作为参数

#include <stdio.h>
void maxV(int a,int b,int *max)
{
  if( a > b)
  {
    *max = a; 
  }else
  {
    *max = b;
  }
}
int main()
{
  //变量定义
  int i,j,k;
  //指针的定义
  int *pi,*pj,*pk;
  //变量的初始化
  i = 10;
  j = 100;
  k = 1000;
  //指针的初始化
  pi = &i;
  pj = &j;
  pk = &k;
  int max;
  maxV(i,j,&max);
  printf("最大的数是:%d\n",max);
  return 0;
}

结果:

最大的数是:100

4、指针如何作为返回值

#include <stdio.h>
void maxV(int a,int b,int *max)
{
        if( a > b)
        {
                *max = a;
        }else
        {
                *max = b;
        }
}
int *maxV2(int *a,int *b)
{
        return *a > *b ? a : b;
}
int main()
{
        //变量定义
        int i,j,k;
        //指针的定义
        int *pi,*pj,*pk;
        //变量的初始化
        i = 10;
        j = 100;
        k = 1000;
        //指针的初始化
        pi = &i;
        pj = &j;
        pk = &k;
        int max;
        maxV(i,j,&max);
        printf("最大的数是:%d\n",max);
        printf("最大的数是:%d\n",*maxV2(&j,&k));
        return 0;
}

结果:

最大的数是:100
最大的数是:1000

5、案例1:完成swap函数,完成两个参数交换的功能

zhenghui@zhlinux:~/codeProject/11指针$ 
zhenghui@zhlinux:~/codeProject/11指针$ cat swap.c 
#include <stdio.h>
void swap(int *p,int *q)
{
  int temp = *p;
  *p = *q;
  *q = temp;
}
int main()
{
  int a=10;
  int b=20;
  swap(&a,&b);
  printf("a=%d,b=%d\n",a,b);
  return 0;
}
zhenghui@zhlinux:~/codeProject/11指针$ 
zhenghui@zhlinux:~/codeProject/11指针$ 
zhenghui@zhlinux:~/codeProject/11指针$ ./a.out 
a=20,b=10
zhenghui@zhlinux:~/codeProject/11指针$

6、案例2:找到最大和第二大的值

题目如下:

方法一:两次循环

第一次:找出最大的值,然后记录下来最大值的位置;

第二次查找的时候把最大值的位置的数据给清空,继续寻找最大的值,那么这一次的最大的值就是第二大的。

#include <stdio.h>
#define ARRAY_SIZE(array) ((int) (sizeof(array) / sizeof(array[0]) ))
/*
 *查找最大的值和第二大的值
 * */
void find_tow_largest(int a[],int n,int *largest,int *second_largest)
{
        //1、找到最大的值
        *largest = a[0];
        //记录下来最大的值的位置
        int maxIndex = 0;
        for(int i = 1;i<n;i++)
        {
                if(*largest < a[i])
                {
                        *largest = a[i];
                        maxIndex = i;
                }
        }
        //2、找第二大的值
        //把最大的值变成最小的值
        a[maxIndex] = -1;
        *second_largest = a[0];
        for(int i = 1;i<n;i++)
        {
                if(*second_largest < a[i])
                {
                        *second_largest = a[i];
                }
"find_tow_larget.c" 54L, 863C                                                              31,2-9       顶端
                        *largest = a[i];
                        maxIndex = i;
                }
        }
        //2、找第二大的值
        //把最大的值变成最小的值
        a[maxIndex] = -1;
        *second_largest = a[0];
        for(int i = 1;i<n;i++)
        {
                if(*second_largest < a[i])
                {
                        *second_largest = a[i];
                }
        }
}
int main()
{
        int a[] = {1,5,2,4,7,5,8,234};
        int n = ARRAY_SIZE(a);
        int largest,second_largest;
        find_tow_largest(a,n,&largest,&second_largest);
        printf("最大的是:%d,第二大的是:%d\n",largest,second_largest);
        return 0;
}

执行结果:

zhenghui@zhlinux:~/codeProject/11指针$ vim find_tow_larget.c
zhenghui@zhlinux:~/codeProject/11指针$
zhenghui@zhlinux:~/codeProject/11指针$
zhenghui@zhlinux:~/codeProject/11指针$ gcc find_tow_larget.c
zhenghui@zhlinux:~/codeProject/11指针$
zhenghui@zhlinux:~/codeProject/11指针$ ./a.out
最大的是:234,第二大的是:8
zhenghui@zhlinux:~/codeProject/11指针$

方法2:排序

可以利用数组的排序来做,任何排序都可以。

这里选用插入排序来做。

zhenghui@zhlinux:~/codeProject/11指针$
zhenghui@zhlinux:~/codeProject/11指针$ cat find_tow_larget.c
#include <stdio.h>
#define ARRAY_SIZE(array) ((int) (sizeof(array) / sizeof(array[0]) ))
/*
 *查找最大的值和第二大的值
 * */
void find_tow_largest(int a[],int n,int *largest,int *second_largest)
{
  //1、找到最大的值
  *largest = a[0];
  //记录下来最大的值的位置
  int maxIndex = 0;
  for(int i = 1;i<n;i++)
  {
    if(*largest < a[i])
    {
      *largest = a[i];
      maxIndex = i;
    }
  }
  //2、找第二大的值
  //把最大的值变成最小的值
  a[maxIndex] = -1;
  *second_largest = a[0];
  for(int i = 1;i<n;i++)
  {
    if(*second_largest < a[i])
    {
      *second_largest = a[i];
    }
  }
}
/*
 *使用排序查找最大的值和第二大的值
 * */
void find_sort_tow_largest(int a[],int n,int *largest,int *second_largest)
{
  //1、初始化
  for(int i = 1;i<n;i++)
  {
    if(a[i-1] > a[i])
    {
      int j = i - 1;
      int temp = a[i];
      while(j > -1 && temp < a[j])
      {
        a[j+1] = a[j];
        j--;
      }
      a[j+1] = temp;
    }
  }
  *largest = a[n-1];
  *second_largest = a[n-2];
}
int main()
{
  int a[] = {1,5,2,4,7,5,8,234};
  int n = ARRAY_SIZE(a);
  int largest,second_largest;
  //find_tow_largest(a,n,&largest,&second_largest);
  find_sort_tow_largest(a,n,&largest,&second_largest);
  printf("最大的是:%d,第二大的是:%d\n",largest,second_largest);
  return 0;
}

结果:

zhenghui@zhlinux:~/codeProject/11指针$ ./a.out
最大的是:234,第二大的是:8
zhenghui@zhlinux:~/codeProject/11指针$
目录
相关文章
|
3月前
|
C语言
【c语言】指针就该这么学(1)
本文详细介绍了C语言中的指针概念及其基本操作。首先通过生活中的例子解释了指针的概念,即内存地址。接着,文章逐步讲解了指针变量的定义、取地址操作符`&`、解引用操作符`*`、指针变量的大小以及不同类型的指针变量的意义。此外,还介绍了`const`修饰符在指针中的应用,指针的运算(包括指针加减整数、指针相减和指针的大小比较),以及野指针的概念和如何规避野指针。最后,通过具体的代码示例帮助读者更好地理解和掌握指针的使用方法。
64 0
|
1月前
|
存储 NoSQL 编译器
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
指针是一个变量,它存储另一个变量的内存地址。换句话说,指针“指向”存储在内存中的某个数据。
86 3
【C语言】指针的神秘探险:从入门到精通的奇幻之旅 !
|
1月前
|
存储 编译器 C语言
【C语言】指针大小知多少 ?一场探寻C语言深处的冒险 !
在C语言中,指针的大小(即指针变量占用的内存大小)是由计算机的体系结构(例如32位还是64位)和编译器决定的。
56 9
|
1月前
|
安全 程序员 C语言
【C语言】指针的爱恨纠葛:常量指针vs指向常量的指针
在C语言中,“常量指针”和“指向常量的指针”是两个重要的指针概念。它们在控制指针的行为和数据的可修改性方面发挥着关键作用。理解这两个概念有助于编写更安全、有效的代码。本文将深入探讨这两个概念,包括定义、语法、实际应用、复杂示例、最佳实践以及常见问题。
45 7
|
2月前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
163 13
|
2月前
|
存储 程序员 编译器
C 语言数组与指针的深度剖析与应用
在C语言中,数组与指针是核心概念,二者既独立又紧密相连。数组是在连续内存中存储相同类型数据的结构,而指针则存储内存地址,二者结合可在数据处理、函数传参等方面发挥巨大作用。掌握它们的特性和关系,对于优化程序性能、灵活处理数据结构至关重要。
|
2月前
|
算法 C语言
C语言中的文件操作技巧,涵盖文件的打开与关闭、读取与写入、文件指针移动及注意事项
本文深入讲解了C语言中的文件操作技巧,涵盖文件的打开与关闭、读取与写入、文件指针移动及注意事项,通过实例演示了文件操作的基本流程,帮助读者掌握这一重要技能,提升程序开发能力。
140 3
|
2月前
|
存储 C语言 开发者
C 语言指针与内存管理
C语言中的指针与内存管理是编程的核心概念。指针用于存储变量的内存地址,实现数据的间接访问和操作;内存管理涉及动态分配(如malloc、free函数)和释放内存,确保程序高效运行并避免内存泄漏。掌握这两者对于编写高质量的C语言程序至关重要。
63 11
|
2月前
|
存储 算法 程序员
C 语言指针详解 —— 内存操控的魔法棒
《C 语言指针详解》深入浅出地讲解了指针的概念、使用方法及其在内存操作中的重要作用,被誉为程序员手中的“内存操控魔法棒”。本书适合C语言初学者及希望深化理解指针机制的开发者阅读。
|
2月前
|
程序员 C语言
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门
C语言中的指针既强大又具挑战性,它像一把钥匙,开启程序世界的隐秘之门。本文深入探讨了指针的基本概念、声明方式、动态内存分配、函数参数传递、指针运算及与数组和函数的关系,强调了正确使用指针的重要性,并鼓励读者通过实践掌握这一关键技能。
44 1