数据结构_P6

原创 2016年06月01日 13:50:48
# include <stdio.h>
/*
	如何通过函数修改实参的值(i的值)  --指针;
	2016年6月1日13:42:29
*/
void f(int *e);     //函数声明必须放在前面

int main(void)
{
	int i = 10;   //现在我要通过f()修改实参i的值
	f(&i);
	printf("i = %d\n", i);
	return 0;
}

void f(int *p)
{
	*p = 1;   //*p等价于i
}


以下是6_2:

# include <stdio.h>
/*
    如何通过函数修改一个指针变量的值int *p中p的值  --也是指针
*   ! 指针的指针:int **p !
	2016年6月1日13:45:04
*/

/*以下都是无法实现的,没有用到指针
void f(int *e);     //函数声明必须放在前面

int main(void)
{
	int i = 10;   
	int *p = &i;  //等价于int *p; p = &i;p现在是一个指针变量,我现在要通过f()修改指针变量p的值
	f(p);   //这样肯定改不了,没用指针,p值不会变的
	printf("p = %p\n", p);
	printf("p = %p\n", p);
	return 0;
}

void f(int *p)
{
	p = (int *)0xFFFFFFFF;   //虽然0xffffffff看起来是地址,但是它只是十六进制的整数,如果要将其赋值给地址话需要强制转换。
}
*/

//以下是对的
void f(int **e);     //函数声明必须放在前面

int main(void)
{
	int i = 10;   
	int *p = &i;  //等价于int *p; p = &i;p现在是一个指针变量,我现在要通过f()修改指针变量p的值
//	f(p);   //这样肯定改不了,没用指针,p值不会变的
	printf("p = %p\n", p);
	f(&p);    //要想改变p值,只能这里取地址用指针
	printf("p = %p\n", p);
	return 0;
}

void f(int **q)    //f(&p)用的是取地址,形参就不能用int *p了,应该用int **p:指针的指针!!
{
	*q = (int *)0xFFFFFFFF;   //虽然0xffffffff看起来是地址,但是它只是十六进制的整数,如果要将其赋值给地址话需要强制转换。
}


版权声明:本文为博主原创文章,转载请注明出处:http://blog.csdn.net/pop_rain

相关文章推荐

数据结构与计算机原理2003p1-6.rar

  • 2008年12月19日 20:25
  • 499KB
  • 下载

数据结构作业p60

  • 2012年09月18日 14:50
  • 2KB
  • 下载

数据结构与算法分析 P86 Stack 栈的实现

链表实现Stack stack.h  #pragma once #include #include struct Node; typedef struct Node *PtrToN...

王道数据结构课后习题 | P37

3、设L为带头节点的单链表,编写算法实现从尾到头反向输出每个节点的值。 我想到的是reverse一下/笑哭 想想这个就有点杀鸡用牛刀的感觉… 看了题解说是可以用递归…卧槽瞬间orzclass S...

数据结构学习 65页 P2

实现代码: main.cpp #include #include "stack.h" #include using namespace std; int main() { Stack...

《数据结构》严蔚敏.吴伟民P63-65.循环队列

///dabbysunshine@qq.com /** 《数据结构》严蔚敏.吴伟民P63-65.循环队列 **/ ///如有BUG,请发邮件联系 #include "stdio....

(数据结构)栈_迷宫求解(严蔚敏P50) _模仿

一般方法: #include"ds.h" #define MAX_COLUM 10 //迷宫最大列数 #define MAX_ROW 10 //迷宫最大行数 #define MAX_NUM 10...

数据结构 P48 算法实现 栈的应用举例-数制转换

#include using namespace std; #define STACK_INIT_SIZE 100     //初始存储容量 #define  STACKINCERMENT 1...

算法之链表练习(数据结构之算法分析:C语言描述 P62 3.3)

/*给你一个链表L和另一个链表P,它们包含以升序排列的整数。操作PrintLots(L,P) 将打印L中那些由P所指定位置上的元素。*/ #include #include struct...

王道数据结构课后习题 | P018

3.长度为L的顺序表,编写一个时间复杂度为O(n),空间复杂度为O(1)的算法,该算法删除线性表中所有值为x的元素。 一看就是典型的双指针问题,于是我写代码如下for(i=0,j=i+1;j...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:数据结构_P6
举报原因:
原因补充:

(最多只允许输入30个字)