随手写了个,你看看吧。
对你的这句“输出数据为a[i]=a[i]+i;”不是很清楚,你可以自己改那句话。
================================================
#include
#include
#include
#define N 10
typedef struct node
{
int iNum;
struct node *link;
}NumLink;
NumLink * creat(int n) // 建立单链表
{
NumLink *p,*h,*s; // *h保存表头结点的指针,*p指向当前结点的前一个结点,*s指向当前结点
int i=0; // 计数器
if((h=(NumLink *)malloc(sizeof(NumLink)))==NULL) // 分配空间并检测
{
printf("不能分配内存空间!");
exit(0);
}
h->link = NULL; // 把表头结点的链域置空
printf("请输入第%d个数值:", i+1);
scanf("%d", &(h->iNum)); // 在当前结点s的数据域中存储数值
p=h; // p指向表头结点
for(i=1; i
if((s= (NumLink *) malloc(sizeof(NumLink)))==NULL) // 分配新存储空间并检测
{
printf("不能分配内存空间!\n");
exit(0);
}
p->link=s; // 把s的地址赋给p所指向的结点的链域,这样就把p和s所指向的结点连接起来了
printf("请输入第%d个数值:", i+1);
scanf("%d", &(s->iNum)); // 在当前结点s的数据域中存储数值
s->link=NULL;
p=s;
}
return(h);
}
void main()
{
int number; // 保存链表中成员个数的变量
int i;
int iArray[N];
NumLink *head; // *head是保存单链表的表头结点地址的指针
NumLink *curr;
number=N;
head=creat(number); // 把所新建的单链表表头地址赋给head
for(i=0; i
if (i==0)
{
iArray[i] = head->iNum+i;
curr = head->link;
}
else
{
iArray[i] = curr->iNum+i;
curr = curr->link;
}
}
for(i=0; i
}