c指针(2)
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h> typedef struct LNode
{
char data;
struct LNode *next;
}LinkList; void CreatList(LinkList *h,char a[],int n)
//void CreatList(char a[],int n)
{
int i;
LinkList *s;
//LinkList *h;
//创建头结点
h=(LinkList *)malloc(sizeof(LinkList)); /*创建头结点*/
if(h==NULL)
{
printf("内存分配失败!\n");
exit();
}
//最后一个节点空
h->next=NULL;
//头插法
for(i=;i<n;i++)
{
s=(LinkList *)malloc(sizeof(LinkList));/*创建新结点*/
if(s==NULL)
{
printf("内存分配失败!\n");
exit();
}
s->data=a[i];
s->next=h->next; /*将*s插在原开始结点之前,头结点之后*/
h->next=s;
}
//head=h;
}
void PrintLink(LinkList *h)
{
LinkList *p=NULL; if(h->next==NULL)
{
printf("空表!\n");
return ;
}
while (h->next)
{
printf(" %c",h->next->data);
h=h->next;
}
printf("\n");
} int main()
{
char c[]={'a','b','c','d','e','f'};
LinkList *head=NULL;
CreatList(head,c,);
PrintLink(head);
return ;
}
编译通过,运行失败。
因为CreatList函数运行完成后,h就被释放掉了,与head无关,这里是传值。
修改head为全局变量,接收h:
#include<stdio.h>
#include<malloc.h>
#include<stdlib.h> typedef struct LNode
{
char data;
struct LNode *next;
}LinkList;
LinkList *head=NULL;
//void CreatList(LinkList *h,char a[],int n)
void CreatList(char a[],int n)
{
int i;
LinkList *s;
LinkList *h;
//创建头结点
h=(LinkList *)malloc(sizeof(LinkList)); /*创建头结点*/
if(h==NULL)
{
printf("内存分配失败!\n");
exit();
}
//最后一个节点空
h->next=NULL;
//头插法
for(i=;i<n;i++)
{
s=(LinkList *)malloc(sizeof(LinkList));/*创建新结点*/
if(s==NULL)
{
printf("内存分配失败!\n");
exit();
}
s->data=a[i];
s->next=h->next; /*将*s插在原开始结点之前,头结点之后*/
h->next=s;
}
head=h;
}
void PrintLink(LinkList *h)
{
if(h->next==NULL)
{
printf("空表!\n");
return ;
}
while (h->next)
{
printf(" %c",h->next->data);
h=h->next;
}
printf("\n");
} int main()
{
char c[]={'a','b','c','d','e','f'}; //CreatList(head,c,6);
CreatList(c,);
PrintLink(head);
return ;
}
那么,如何用局部变量来接收头指针呢?
c++可以用 CreatList(LinkList *&h,char a[],int n),那么c呢?
先到这里,有空继续写。
c指针(2)的更多相关文章
- TODO:Golang指针使用注意事项
TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. ...
- enote笔记法使用范例(2)——指针(1)智能指针
要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在&l ...
- C++虚函数和函数指针一起使用
C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...
- C++11 shared_ptr 智能指针 的使用,避免内存泄露
多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...
- c 数组与指针的使用注意事项
数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这 ...
- Marshal.Copy将指针拷贝给数组
lpStatuss是一个UNITSTATUS*的指针类型实例,并包含SensorDust字段 //定义一个数组类型 byte[] SensorDust = new byte[30] //将指针类型拷贝 ...
- C++智能指针
引用计数技术及智能指针的简单实现 基础对象类 class Point { public: Point(int xVal = 0, int yVal = 0) : x(xVal), y(yVal) { ...
- EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针
一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码: #include <iostream> using namespace std; int func1(){ //返回 ...
- 智能指针shared_ptr的用法
为了解决C++内存泄漏的问题,C++11引入了智能指针(Smart Pointer). 智能指针的原理是,接受一个申请好的内存地址,构造一个保存在栈上的智能指针对象,当程序退出栈的作用域范围后,由于栈 ...
- 智能指针unique_ptr的用法
unique_ptr是独占型的智能指针,它不允许其他的智能指针共享其内部的指针,不允许通过赋值将一个unique_ptr赋值给另一个unique_ptr,如下面错误用法: std::unique_pt ...
随机推荐
- RobotFramwork中实现oracle数据库的连接(终于解决cx_oracle问题)
RobotFramework连接数据库有java实现,也有python实现的,现在研究的python实现的,java还没尝试.有兴趣的参考后面的转载文章. 步骤(也转载了别人的文章,因为写的比 ...
- python---函数定义、调用、参数
1.函数定义和调用 下面def test部分的代码块是函数定义:test(2,3)则是函数调用 def test(a,b): print(a) print(b) test(,) 2.必填参数,即函数调 ...
- UVA - 1612 Guess (猜名次)(贪心)
题意:有n(n<=16384)位选手参加编程比赛.比赛有3道题目,每个选手的每道题目都有一个评测之前的预得分(这个分数和选手提交程序的时间相关,提交得越早,预得分越大).接下来是系统测试.如果某 ...
- HDU 5464:Clarke and problem
Clarke and problem Accepts: 130 Submissions: 781 Time Limit: 2000/1000 MS (Java/Others) Memory L ...
- Egret - EUI - 隐藏滚动条
<e:Skin> <e:VScrollBar autoVisibility="false" visible="false"/> < ...
- BGP(IBGP“内部路由器”和EBGP“外部路由器”)命令解析
BGP:基于策略的路径向量路由协议. ①:(attribute)属性描述路径. ②:使用TCP(端口179)作为传输协议——(IBGP多使用loopback端口建立update-source) IBG ...
- EVANYOU尤大个人网站主页CANVAS三角彩带效果分析学习
尤雨溪网站三角彩带效果 效果: 源码 <!DOCTYPE html> <html lang="en"> <head> <meta char ...
- linux_c_tcp_example
server #include <stdio.h> #include <stdlib.h> #include <string.h> #include <uni ...
- openstack trove weekly meeting时间即将更改
为了平衡英国.巴黎.德国.美国和中国开发者的作息习惯,openstack trove项目组在5月18日的weekly meeting上开始讨论新的开会时间. 当前的开会时间是,周三 UTC 18:00 ...
- JZOJ-2019-11-5 B组
T1 给出一二维01矩阵\(f_{i,j}\), 定义点\((x_a, y_a), (x_b, y_b)\)的「距离」为\(max\{|x_a-x_b|, |y_a-y_b|\}\) 求出一矩阵\(w ...