6-6 求单链表结点的阶乘和 (15 分)
作者:互联网
本题要求实现一个函数,求单链表L
结点的阶乘和。这里默认所有结点的值非负,且题目保证结果在int
范围内。
函数接口定义:
int FactorialSum( List L );
其中单链表List
的定义如下:
typedef struct Node *PtrToNode; struct Node { int Data; /* 存储结点数据 */ PtrToNode Next; /* 指向下一个结点的指针 */ }; typedef PtrToNode List; /* 定义单链表类型 */
裁判测试程序样例:
#include <stdio.h> #include <stdlib.h> typedef struct Node *PtrToNode; struct Node { int Data; /* 存储结点数据 */ PtrToNode Next; /* 指向下一个结点的指针 */ }; typedef PtrToNode List; /* 定义单链表类型 */ int FactorialSum( List L ); int main() { int N, i; List L, p; scanf("%d", &N); L = NULL; for ( i=0; i<N; i++ ) { p = (List)malloc(sizeof(struct Node)); scanf("%d", &p->Data); p->Next = L; L = p; } printf("%d\n", FactorialSum(L)); return 0; } /* 你的代码将被嵌在这里 */
输入样例:
3 5 3 6
输出样例:
846
我的答案:
int FactorialSum( List L ) { int j=1,sum=0; while(L!=NULL) { int a=1; for(j=1;j<=L->Data;j++) { a*=j; } sum+=a; L=L->Next; } return sum; }
疑问点:
/*为什么如果int a=1 放在while 循环外答案就会出现错误
*/
标签:Node,结点,单链,15,int,PtrToNode,List,阶乘 来源: https://www.cnblogs.com/yichu2021/p/15046589.html