题目详情
当前位置:首页 > 计算机考试 > 软件测试工程师
题目详情:
发布时间:2023-11-25 19:23:13

[简答题]论述题3(20分): 已知C源程序如下: /*分数运算 fsys.c*/ #include<stdio.h> int main( ) { long int a,b,c,d,i,x,y,z; char op; printf("两分数b/a,d/c作+、-、*、/四则运算。结果为分数。/n"); printf("请输入分数运算式:b/a op d/c/n"); scanf("%ld/%ld%c%ld%ld",&b,&a,&op,&d,&c); if(a==0||c==0){ printf("分母为0,输入错误!/n"); return(0); } if(op==’+’){ y=b*c+d*a; x=a*c; /*运算结果均为y/x*/ } if(op==’-’){ y=b*c-d*a; x=a*c; } if(op==’*’){ y=b*d; x=a*c; } if(op==’/’){ y=b*c; x=a*d; } z=x; if(x>y)z=y; i=z; while(i>1){ if(x%i==0&&y%i==0){x=x/i;y=y/i;continue;}; i——; } printf("%ld/%ld%c%ld/%ld=%ld/%ld./n",b,a,op,d,c,y,x); return 0; } 画出程序中main函数的控制流程图。

更多"论述题3(20分): 已知C源程序如下: /*分数运算 fsys."的相关试题:

[简答题]论述题3(20分): 已知C源程序如下: /*分数运算 fsys.c*/ #include<stdio.h> int main( ) { long int a,b,c,d,i,x,y,z; char op; printf("两分数b/a,d/c作+、-、*、/四则运算。结果为分数。/n"); printf("请输入分数运算式:b/a op d/c/n"); scanf("%ld/%ld%c%ld%ld",&b,&a,&op,&d,&c); if(a==0||c==0){ printf("分母为0,输入错误!/n"); return(0); } if(op==’+’){ y=b*c+d*a; x=a*c; /*运算结果均为y/x*/ } if(op==’-’){ y=b*c-d*a; x=a*c; } if(op==’*’){ y=b*d; x=a*c; } if(op==’/’){ y=b*c; x=a*d; } z=x; if(x>y)z=y; i=z; while(i>1){ if(x%i==0&&y%i==0){x=x/i;y=y/i;continue;}; i——; } printf("%ld/%ld%c%ld/%ld=%ld/%ld./n",b,a,op,d,c,y,x); return 0; } 设计一组测试用例,使该程序所有函数的语句覆盖率和分支覆盖率均能达到100%。如果认为该程序的语句覆盖率或分支覆盖率无法达到100%,需说明为什么。
[简答题]

论述题3: 已知C源程序如下: /*longIntAdd*/ #include<stdio.h> #include<string.h> #define LENGTH 81 void addLInt(char s1[],char s2[]); void reverse(char s[]); int main( ) { char intstr1[LENGTH],intstr2[LENGTH]; printf("请输入超长整数的被加数和加数:/n"); scanf("%s%s",intstr1,intstr2); addLInt(intstr1,intstr2); printf("超长整数和为:%s",intstr1); return 0; } void addLInt(char s1[],char s2[]) { int i=0,tmp,c=0; char s[LENGTH]; if(strlen(s1)<strlen(s2)){ strcpy(s,s1); strcpy(s1,s2); strcpy(s2,s); } reverse(s1);reverse(s2); while(s2[i]!=;/0’){ tmp=s1[i]-’0’+s2[i]-’0’+c; 81[i]=tmp%10+’0’; c=tmp/10; i++; } while(si[1]!=’/0’&&c){ tmp=s1[i]-’0’+c; s1[i]=tmp%10+’0’; c=tmp/10; i++; } If(c){ s1[i++]=c+’0’; s1[i]=’/0’; } reverse(s1); } void reverse(char s[]) { int i,j,c; for(i=0,j=strlen(s)-1;i<j;i++,j--){ c=s[i]; s[i]=s[j]; s[j]=c; } }

画出程序中函数addLInt的控制流程图;
[简答题]

已知C源程序如下:
/*分数运算 fsys.c*/
#include<stdio.h>
int main( )

long int a,b,c,d,i,x,y,z;
char op;
printf("两分数b/a,d/c作+、-、*、/四则运算。结果为分数。/n");
printf("请输入分数运算式:b/a op d/c/n");
scanf("%ld/%ld%c%ld%ld",&b,&a,&op,&d,&C) ;
if(a==0||c==0)
printf("分母为0,输入错误!/n");
return(0);

if(op==’+’)
y=b*c+d*a;
x=a*c; /*运算结果均为y/x*/

if(op==’-’)
y=b*c-d*a;
x=a*c;

if(op==’*’)
y=b*d;
x=a*c;

if(op==’/’)
y=b*c;
x=a*d;

z=x;
if(x>y)z=y;
i=z;
while(i>1)
if(x%i==0&&y%i==0)x=x/i;y=y/i;continue;;
i——;

printf("%ld/%ld%c%ld/%ld=%ld/%ld./n",b,a,op,d,c,y,x);
return 0;
 

[简答题]已知C源程序如下:
/*分数运算 fsys.c*/
#include<stdio.h>
int main( )

long int a,b,c,d,i,x,y,z;
char op;
printf("两分数b/a,d/c作+、-、*、/四则运算。结果为分数。/n");
printf("请输入分数运算式:b/a op d/c/n");
scanf("%ld/%ld%c%ld%ld",&b,&a,&op,&d,&C) ;
if(a==0||c==0)
printf("分母为0,输入错误!/n");
return(0);

if(op==’+’)
y=b*c+d*a;
x=a*c; /*运算结果均为y/x*/

if(op==’-’)
y=b*c-d*a;
x=a*c;

if(op==’*’)
y=b*d;
x=a*c;

if(op==’/’)
y=b*c;
x=a*d;

z=x;
if(x>y)z=y;
i=z;
while(i>1)
if(x%i==0&&y%i==0)x=x/i;y=y/i;continue;;
i——;

printf("%ld/%ld%c%ld/%ld=%ld/%ld./n",b,a,op,d,c,y,x);
return 0;

设计一组测试用例,使该程序所有函数的语句覆盖率和分支覆盖率均能达到100%。如果认为该程序的语句覆盖率或分支覆盖率无法达到100%,需说明为什么。
[简答题] 已知C源程序如下:
/ * A simple mailing list example using an array of structures. */
#include<stdion. h>
#include<stdlib. h>
define MAX 4
struct adck {
char name[30];
char street[40];
char city[20];
unsigned long int zip;
)addr_l ist[MAX];
void init_list(void),enter(void);
void deleteAddr(void),list(void);
int menu_select(void),find_free(void);
int main(void)
{
char choice;
init_list( );/ * initialize the structure array * /
for(;;){
choice=menu_select( );
switch(choice){
case 1:enter( );
break;
case 2:deleteAddr( );
break;
case 3:list( );
break;
case 4:exit(0);
}
}
return 0;
}
/ * Initialize the list. */
void init list(void)
{
register int t;
for(t=0;t<MAX;++t)addr_list[t],name[0]=/0;
}
/ *
[简答题]

已知C源程序如下:
#include #include void reverse(char s[]){ int c,i,j; for(i=0,j=strlen(s)-1;i0){ if(number%16<10) s[i++]=number%16+0; else switch(number%16){ case 10:s[i++]=A;break; case 11:s[i++]=B;break; case 12:s[i++]=C;break; case 13:s[i++]=D;break; case 14:s[i++]=E;break; case 15:s[i++]=F;break; default:printf("Error");break; } number/=16; } s[i]=//0; reverse(s); } int main( ){ unsigned int number; int i=0; char s[50]; printf("%s","please input number://n"); scanf("%d",&number); getHex(number,s); i=0; while(s[i]) printf("%c",s[i++]); return 0; }

画出程序中所有函数的控制流程图;
[简答题]针对一下C语言程序,请按要求回答问题。 已知weekday. c源程序如下: #include<stidio. h> #include<conio. h> / *主函数* / Int main( ) { Char letter; Printf("please input the first letter,"Y’to exit!/n"); While((letter=getch( ))!="Y")//当输入字母为Y时结束 { Switch(letter) { Case’S’: Printf("%c/n",letter); Printf("please input second letter/n");//输入第二个字母 If((letter=getch( ))==’a’) Printf("Saturday/n"); Else if(letter==’u’) Printf("Sunday/n"); Else printf(’data error/n); Break; Case’F’: Printf("fridaykn"); Break; Case ’M’: Printf("mondayha"); Break; Case ’T’: Printf("%c/n",letter); Printf("please input second letter/a");//输入第二个字母 If((letter=getch( ))==’u’) Printf("Tuesday/n"): Else if(letter==’h’) Printf("Thursday/n"); Break; Case ’W’: Printf("Wednesday/n"); } } Return 0; } (1) 画出主函数main的控制流程图; (2) 设计一组测试用例,使main函数的语句覆盖率尽量达到100%; (3) Main函数的语句覆盖率能否达到100%如果认为无法达到,需说明原因。
[简答题]已知C源程序如下:
/*Input today’s date,output tomorrow’s date*/
/*version 2*/
#include<stdio.h>
struct ydate
int day;int month;int year;;
int leap(struct ydate d)
if((d.year%4==0&&d.year%100!=0)||(d.year%400==0))
    return 1;
   else
    return 0;

int numdays(struct ydate d)
int day;
   static int daytab[]=
    31,28,31,30,31,30,31,31,30,31,30,31);
   if(leap(d)&&d.month==2)
    day=29;
   else
    day=daytab[d.month-1];
   return day;

int main(void)
struct ydate today,tomorrow;
   printf("format of date is:year,month,day 输入的年、月、日之间应用逗号隔开/n");
   printf("today is:");
   scanf("%d,%d,%d",&today.year,&today.month,&today.day);
   while(0>=today.year
|| today.year>65535 || 0>=today.month || today.month>12) ||
0>=today.day || today.day>numdays(today))
     printf("input date error!reenter the day!/n");
printf("today is:");
scanf("
[简答题]

已知C源程序如下:
/*Input today’s date,output tomorrow’s date*/
/*version 2*/
#include<stdio.h>
struct ydate
int day;int month;int year;;
int leap(struct ydate d)
if((d.year%4==0&&d.year%100!=0)||(d.year%400==0))
    return 1;
   else
    return 0;

int numdays(struct ydate d)
int day;
   static int daytab[]=
    31,28,31,30,31,30,31,31,30,31,30,31);
   if(leap(d)&&d.month==2)
    day=29;
   else
    day=daytab[d.month-1];
   return day;

int main(void)
struct ydate today,tomorrow;
   printf("format of date is:year,month,day 输入的年、月、日之间应用逗号隔开/n");
   printf("today is:");
   scanf("%d,%d,%d",&today.year,&today.month,&today.day);
   while(0>=today.year
|| today.year>65535 || 0>=today.month || today.mon

[简答题] 针对以下C语言程序,请按要求回答问题。
已知link. c源程序如下:
/*link. c程序对单向链表进行操作,首先建立一个单向链表,然后根据用户的选择可以对其进行插入结点、删除结点和链表反转操作*/
#include<stdio. h>
#include<stdlib. h>
typedef struct list_node * list_pointer; //定义链表指针
typedef struct list_node{ //定义链表结构
int data;
list_pointer link;
}list_node;
//用到的操作函数
list_pointer create( ); //建立一个单向链表
void insert(list_pointer * p_ptr,list_pointer node); //在node后加入一个新的结点
void delete_node(list_pointer * p_ptr,list_pointer trail,list_pointer node);
//删除前一个结点是trail的当前结点node
void print(list_pointer * p_ptr); //打印链表结点中的值
list_pointer invert(list_pointer lead); //反转链表
int main( )
{
list_pointer ptr=NULL;
list_pointer node,trail;
list_pointer * P=&ptr;
int choose,location,i;
printf("you should create a link first:/n");
//建立一个单向链表
prt=create( ); //ptr指向链表的第一个结点
print(p
[简答题]

已知计算个人所得税的C源程序如下:
/*sds.c*/
double sds(double y)

double x;

if(y<=2000) x=0;
else if(y<=3600)
x=(y-2000)*0.05;
else if(y<=6600)
x=sds(3600)+(y-3600)*0.1;
else if(y<=21600)
x=sds(6600)+(y-6600)*0.2;
else if(y<=61600)
x=sds(21600)+(y-21600)*0.3;
else if(y<=101600)
x=sds(61600)+(y-61600)*0.4;
else x=sds(101600)+(y-101600)*0.5;
return(x);

#include<stdio.h>
int main( )

double y,x;
printf("请输入收入:/n");
scanf("%If",&y);
x=sds(y);
printf("应缴个人所得税为:sds(%9.2f)=%9.2f",y,x);
return 0;

画出程序中函数sds的控制流程图。
[简答题]

已知检查括号匹配及注释、字符串处理的C源程序如下:
#include<stdio.h>

int brace,brack,paren;

void in_quote(int c);
void in_comment(void);
void search(int c);

/*rudimentary syntax checKer for C program*/
int main( )

int c;
extern int brace,brack,paren;
while((c=getchar( ))!=EOF)
if(c==’/’)
if((c=getchar( ))==’*’)
in_comment( ); /*inside comment*/
else
search(C) ;
else if(c==’/"||c=="")
in_quote(c); /*inside quote*/
else
search(c);
if(brace<0) /*output errors*/
printf("Unbalanced braces/n");
brace=0;
else if(brack<0)
printf("Unbalanced brackets/n");
brack=0;
else if(paren<0)
printf("Unbalanced parentheses/n");
paren=0;


if(brace>0) /*output errors*/

[简答题]

已知检查括号匹配及注释、字符串处理的C源程序如下: #include<stdio.h> int brace,brack,paren; void in_quote(int c); void in_comment(void); void search(int c); /*rudimentary syntax checKer for C program*/ int main( ) { int c; extern int brace,brack,paren; while((c=getchar( ))!=EOF){ if(c==’/’){ if((c=getchar( ))==’*’) in_comment( ); /*inside comment*/ else search(C) ; }else if(c==’/"||c=="") in_quote(c); /*inside quote*/ else search(c); if(brace<0){ /*output errors*/ printf("Unbalanced braces/n"); brace=0; }else if(brack<0){ printf("Unbalanced brackets/n"); brack=0; }else if(paren<0){ printf("Unbalanced parentheses/n"); paren=0; } } if(brace>0) /*output errors*/ printf("Unbalanced braces/n"); if(brack>0) printf("Unbalanced brackets/n"); if(paren>0) printf("Unbalanced parentheses/n"); return 0; } /*search:search for rudimentary syntax errors*/ void search(int c) { extern int brace,brack,paren; if(c==&rsqu

我来回答:

购买搜题卡查看答案
[会员特权] 开通VIP, 查看 全部题目答案
[会员特权] 享免全部广告特权
推荐91天
¥36.8
¥80元
31天
¥20.8
¥40元
365天
¥88.8
¥188元
请选择支付方式
  • 微信支付
  • 支付宝支付
点击支付即表示同意并接受了《购买须知》
立即支付 系统将自动为您注册账号
请使用微信扫码支付

订单号:

请不要关闭本页面,支付完成后请点击【支付完成】按钮
恭喜您,购买搜题卡成功
重要提示:请拍照或截图保存账号密码!
我要搜题网官网:https://www.woyaosouti.com
我已记住账号密码