- 1、本文档共11页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2019年电大面向对象程序设计作业答案参考资料必考重点.doc
一、编程题。根据程序要求,写出函数的完整定义。(40分)
1.写一个函数,找出给定字符串中大写字母字符(即’A’-‘Z’这26个字母)的个数(如字符串”China Computer Wrold”中大写字母字符的个数为3个)。
函数的原型: int CalcCapital (char *str);
函数参数: str为所要处理的字符串;
函数返回值:所给字符串中数字字符的个数
答:
int CalcCapital (char *str)
{
if (str == NULL) return 0; //判断字符指针是否为空
int num_of_Capital = 0; //记录大写字母字符个数的变量,初值为0
for(int i=0; str[i] != 0x0; i++)
if (str[i] = A str[i] = Z) num_of_ Capital ++; //若是大写字母,则总数加1?
return num_of_ Capital; //返回大写字母字符数
}
2.写一个函数,用递归函数完成以下运算:
sum(n) = 1 – 1/2 + 1/3 – 1/4 + … -(1/n)*(-1)n (其中n0)
函数原型: float sum(int n);
函数参数:n为正整数。
函数返回值:相应于给定的n,右边表达式运算结果。
提示:你可以使用递归表达式: sum(n) = sum(n-1) -(1/n)*(-1)n
答:
float sum(int n)
{
if (n == 1) return 1;
else return sum(n-1) -(1.0/n)*(-1)n;
}
3. 给定新数值,在一个按节点所存放数值从大到小排序的链表中,找适当位置插一个新节点,仍保持有序的链表,写一个函数,完成此操作。
函数的原型: Node * InsNode(Node * head, int newValue);
其中,链表节点的定义如下:
struct Nodee{
int Value; //存放数值
Node * next; //指向链表中的下一个节点
};
函数参数:函数的第一个参数head指向链表头一节点的指针,如果链表为空,则head的值为NULL。第二个参数newValue为所给定的插入新节点的新数值。
函数返回值:当成功地插入新的节点时,函数返回指向新链表头一节点的指针,否则,若不能申请到内存空间,则返回NULL。
答:
Node * insNode(Node * head, int newValue)
{
Node * newNode = new Node; //申请新的节点空间
if (newNode == NULL) return NULL;//
newNode-data = newValue; //填充新节点的内容
newNode-next = NULL;
Node *pre, *cur;
Pre = head;
if (head == NULL) head = newNode; //插入到空链表的表头
else
if(newValue=head-Value){
newNode-next=head;
head = newNode; //插入到链表的表头
}
else{ //在链表寻找插入点
Node *cur,*pre = head;
while(pre-next != NULL){
cur = pre-next;
if(newValue = cur-Value) break;
else pre = cur;
}
if(pre-next!= NULL) newNode-next = cur;//若非末尾,则有下一节点
pre-next = newNode; //将新节点插入
}
}
return head;
}
4.写一个函数,找出给定数组中具有最小值的元素。
函数的原型:
char MinCode(char charAry[]);
函数参数:charAry所要处理的字符数组名;
函数返回值:返回具有最小ASCII码的字符。
答:
char MinCode(char charAry[],int len=10)
{
char mixCode = 0x0;
f
您可能关注的文档
- 2019年电大国际贸易实务期末复习资料考试必考重点.doc
- 2019年电大国际贸易实务期末重点复习指导资料考试必考重点【必威体育精装版精华打印版】.doc
- 2019年电大国际贸易实务试题及答案必考重点.doc
- 2019年电大国际私法考试必考重点(已排版).doc
- 2019年电大国际私法期末复习重点知识考试必考重点【已整理排版】.doc
- 2019年电大国际投资学考试资料必考重点.doc
- 2019年电大国民经济核算网考题库资料必考重点【单选、多选、判断、按字母排版】.doc
- 2019年电大汉语言文学《中国文化概观》形考作业1-4指导答案参考必考重点.doc
- 2019年电大行政法学案例分析复习考试试题资料.docx
- 2019年电大行政法学案例分析期末复习必备资料必考重点【必威体育精装版已排版】.doc
文档评论(0)