问题 问答题 案例分析题

导游员王某在一次带团旅游的过程中,因途中一处山体滑坡阻断了唯一的一条通道,耽误了一天行程,原定在H市游览一天后入住A饭店的计划落空。王某赶紧与饭店联系,无奈移动电话没有讯号,附近又没有公用电话。第二天到达H市后,王某即赶往饭店要求改订当晚的住房,刚好饭店当天有一个大型会议在此召开,没有空房。王某向饭店出示了山体滑坡阻碍交通的材料,要求饭店将已收定金退还。饭店称由于他们的预订,使饭店不敢将空房租给其他客人,饭店已经遭受了损失,因此定金不能退还。

王某看到问题不能就此解决,便到其他地方去联系住房。因A饭店的定金没有退还,王某便订了一个比A饭店低一个档次的饭店。下午入住时,游客看到合同上的三星级饭店变成了眼前的二星级饭店,非常愤慨,要求换其他的三星级饭店,王某除告知事情原委外,强调是不可抗力因素所致。

请你运用所学法律知识分析此案,并回答下列问题:

(1)什么是不可抗力?

(2)王某能否要求A饭店退还定金?为什么?

(3)游客的要求是否合理?为什么?

答案

参考答案:

(1)不可抗力指不能预见、不能避免且不能克服的客观情况。

(2)可以。原因是:山体滑坡属于不可抗力,根据《合同法》的规定,不可抗力导致合同不能履行,可以减免或免除违约责任。本案中的王某在遭遇不可抗力以后,履行了告知义务和提供证明义务。所以,王某有理由要求退还定金。

(3)合理。原因是:双方合同约定的住宿标准是三星级饭店,游客有权要求王某按合同约定履行义务。

问答题

【函数1说明】
函数compare(SqList A, SqList B)的功能是:设A=(al,…,am)和B=(b1,…,bn)均为顺序表,“比较”,两个顺序表A和B的大小。设A’ 和B’ 分别为A和B中除去最大共同前缀后的子表(例如,A=(y,x,x,z,x,z),B=(y,x,x,2,y,x,x,z),则两者中最大的共同前缀为 (y,x,x,z),在两表中除去最大共同前缀后的子表分别为A’=(x,z)和B’=(y,x,x,z))。若 A’=B’=空表,则A=B;若A’=空表,而B’≠空表,或者两者均不为空表,且A’的首元小于 B’首元,则A<B:否则A>B。
提示:算法的基本思想为:若相等,则j+1,之后继续比较后继元素;否则即可得出比较结果。显然,j的初值应为0,循环的条件是j不超出其中任何一个表的范围。若在循环内不能得出比较结果,则循环结束时有3种可能出现的情况需要区分。
【函数1】
int compare ( SqListA, SqList B)
{
//若A<B,则返回-1;若A=B,则返回0:若A>B,则返回1
j =0;
while(i< (1) &&j<B. length)
if(A. elem[j] < B. elem[j] )return(-1)
else if(A. elem[j] > B. elem[j] )return(1);
else (2) ;
if(A. length == B. length) return(0);
else if(A. length<B. length)return(-1);
else return(1)
}//compare
//函数1的时间复杂度是 (3)
【函数2说明】
函数exchanse_L(SLnk&L,int m)的功能是:用尽可能少的辅助空间将单链表中前m个结点和后n个结点的互换。即将单链表(a1、a2…,am,b1,b2,…,bn)改变成(b1,b2,…,bn,a1, a2,…,am,)。
【函数2】
void exchange_L(SLink &L, int m)
{
if( (4) &&L->next) //链表不空且Lm!=0
{
P = L->next; k=1;
while( k < m&&p) //查找am,所在结点
{
P= (5) ;++k;
}
if( (6) &&p->next)//n! =0 时才需要修改指针
ha = L -> next; //以指针ha记a1结点的位置
L -> next = p -> next; //将B1结点链接在头结点之后
p -> next = NULL; //设am的后继为空
q= (7) ; //令q指向b1结点
while(q->next)q = (8) ; //查找bn结点
q->>next= (9) ; //将a1结点链接到bn结点之后
}
}
}
//函数2的时间复杂度是 (10)

单项选择题