#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)的更多相关文章

  1. TODO:Golang指针使用注意事项

    TODO:Golang指针使用注意事项 先来看简单的例子1: 输出: 1 1 例子2: 输出: 1 3 例子1是使用值传递,Add方法不会做任何改变:例子2是使用指针传递,会改变地址,从而改变地址. ...

  2. enote笔记法使用范例(2)——指针(1)智能指针

    要知道什么是智能指针,首先了解什么称为 “资源分配即初始化” what RAII:RAII—Resource Acquisition Is Initialization,即“资源分配即初始化” 在&l ...

  3. C++虚函数和函数指针一起使用

    C++虚函数和函数指针一起使用,写起来有点麻烦. 下面贴出一份示例代码,可作参考.(需要支持C++11编译) #include <stdio.h> #include <list> ...

  4. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  5. c 数组与指针的使用注意事项

    数组变量和指针变量有一点小小的区别 所以把数组指针赋值给指针变量的时候千万要小心 加入把数组赋值给指针变量,指针变量只会包含数组的地址信息 而对数组的长度一无所知 相当于指针丢失了一部分信息,我们把这 ...

  6. Marshal.Copy将指针拷贝给数组

    lpStatuss是一个UNITSTATUS*的指针类型实例,并包含SensorDust字段 //定义一个数组类型 byte[] SensorDust = new byte[30] //将指针类型拷贝 ...

  7. C++智能指针

    引用计数技术及智能指针的简单实现 基础对象类 class Point { public: Point(int xVal = 0, int yVal = 0) : x(xVal), y(yVal) { ...

  8. EC笔记:第三部分:17、使用独立的语句将newed对象放入智能指针

    一般的智能指针都是通过一个普通指针来初始化,所以很容易写出以下的代码: #include <iostream> using namespace std; int func1(){ //返回 ...

  9. 智能指针shared_ptr的用法

    为了解决C++内存泄漏的问题,C++11引入了智能指针(Smart Pointer). 智能指针的原理是,接受一个申请好的内存地址,构造一个保存在栈上的智能指针对象,当程序退出栈的作用域范围后,由于栈 ...

  10. 智能指针unique_ptr的用法

    unique_ptr是独占型的智能指针,它不允许其他的智能指针共享其内部的指针,不允许通过赋值将一个unique_ptr赋值给另一个unique_ptr,如下面错误用法: std::unique_pt ...

随机推荐

  1. .NET via C#笔记17——委托

    一.委托的内部实现 C#中的委托是一种类型安全的回调函数,假设有这样一个委托: internal delegate void Feedback(int value); 编译器会生成一个类: inter ...

  2. 04-String——课后作业1:字串加密

    题目:请编写一个程序,加密或解密用户输入的英文字串要求设计思想.程序流程图.源代码.结果截图. 程序设计思想:首先由用户选择是加密还是解密,利用String类中的charAt函数依次取出字串中的字符, ...

  3. 65.ORM查询条件:gte,gt,lte和lt的使用

    1. gte: 代表的是大于等于,英文全称为:great than equal.举例:找到文章id大于等于3等文章,示例代码如下: 定义模型的示例代码如下: from django.db import ...

  4. pip2 install protobuf==2.6.1

    [libprotobuf FATAL google/protobuf/stubs/common.cc:61] This program requires version 3.5.0 of the Pr ...

  5. UVA_11525 树状数组的活用 二分

    我们知道1——k有K!种排列,现在给定k和n,要你按字典序输出 第n种排列的数列 而且题目给的 n是 n=S1(k-1)!+S2(k-2)!+...+Sk-1*1!+Sk*0!(0=<Si< ...

  6. Codeforces 433C #248_div1_A 中位数的应用

    擦..今天这套题好尼玛难啊,做了一个小时,连一题都没做出来,而且还没什么头绪 查了下出题人,师大附中的 14年毕业 13年拿到的国家集训队资格 保送清华 题意是 给一串序列,计算一个值,这个值是 相邻 ...

  7. Vue 指令 v-text v-html

    有三个指令达到的效果是一样的 {{JS表达式}}  差值表达式 v-text="JS表达式" v-html="JS表达式"   //会自动解析tag js表达式 ...

  8. go 的参数传递

    再go语言中没有引用传递,所有都是按照值拷贝的方式传递的. 数组:实际就是堆栈上的一段连续内存,和c类似.(可以更加反编译代码推断 go tool compile -S main.go > ma ...

  9. LVS三种模式区别

    参考文档 http://www.magedu.com/65436.html 名词:CIP 客户端IP地址   VIP:即DS服务器上的代理IP地址,也是客户端访问的执行IP地址 1.NAT模式 ①.客 ...

  10. 刷题32. Longest Valid Parentheses

    一.题目说明 题目是32. Longest Valid Parentheses,求最大匹配的括号长度.题目的难度是Hard 二.我的做题方法 简单理解了一下,用栈就可以实现.实际上是我考虑简单了,经过 ...