一、选择题(每小题1分,共40分)
(1)下列叙述中正确的是
A)算法就是程序
B)设计算法时只需要考虑数据结构的设计
C)设计算法时只需要考虑结果的可靠性
D)以上三种说法都不对
(2)下列关于线性链表的叙述中,正确的是
A)各数据结点的存储空间可以不连续,但它们的存储顺序与逻辑顺序必须一致
B)各数据结点的存储顺序与逻辑顺序可以不一致,但它们的存储空间必须连续
C)进行插入与删除时,不需要移动表中的元素
D)有序的线性链表也可以方便地进行二分查找
(3)下列关于二叉树的叙述中,正确的是
A)叶子结点总是比度为2的结点少一个
B)叶子结点总是比度为2的结点多一个
c)叶子结点数是度为2的结点数的两倍
D)度为2的结点数是度为1的结点数的两倍
(4)软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是
A)学生成绩管理系统 B)C语言编译程序
C)UNIX操作系统 D)数据库管理系统
(5)某系统总体结构图如下图所示:

该系统总体结构图的深度是
A)2 B)3 C)6 D)7
(6)程序调试的任务是
A)设计测试用例 B)验证程序的正确性
C)发现程序中的错误 D)诊断和改正程序中的错误
(7)下列关于数据库设计的叙述中,正确的是
A)在需求分析阶段建立数据字典 B)在概念设计阶段建立数据字典
C)在逻辑设计阶段建立数据字典 D)在物理设计阶段建立数据字
(8)数据库系统的三级模式不包括
A)概念模式 B)内模式 C)外模式 D)数据模式
(9)有三个关系R、S和T如下:

则由关系R和s得到关系T的操作是
A)自然连接 B)差 C)交 D)并
(10)下列选项中属于面向对象设计方法主要特征的是
A)继承 B)自顶向下 C)模块化 D)逐步求精
(11)下列叙述中错误的是
A)C语言编写的函数源程序,其文件名后缀可以是.C
B)C语言编写的函数都可以作为一个独立的源程序文件
C)C语言编写的每个函数都可以进行独立的编译并执行
D)一个C语言程序只能有一个主函数
(12)下列关于程序模块化的叙述,错误的是
A)把程序分成若干相对独立的模块,可便于编码和调试
B)把程序分成若干相对独立、功能单一的模块,可便于重复使用这些模块
C)可采用自底向上、逐步细化的设计方法把若干独立模块组装成所要求的程序
D)可采用自项向下、逐步细化的设计方法把若干独立模块组装成所要求的程序
(13)下列关于C语言常量的叙述,错误的是
A)所谓常量,是指在程序运行过程中,其值不能被改变的量
B)常量分为整型常量、实型常量、字符常量和字符串常量
C)常量可分为数值型常量和非数值型常量
D)经常被使用的变量可以定义成常量
(14)若有定义语句:int a=10;double b=3.14;,则表达式'A'+a+b值的类型是
A)char B)int C)double D)float
(15)若有定义语句:int x=12,y=8,z;,在其后执行语句z=0.9+x/y;,则z的值为
A)1 B)1.9 C)2 D)2.4
(16)若有定义:int a,b;,通过语句scanf("%d;%d",&a,&B);,能把整数3赋给变量a,5
赋给变量b的输入数据是
A)3 5 B)3,5 C)3;5 D)35
(17)若有定义语句:int k1=10,k2=20;,执行表达式(k1=k1>k2)&&(k2=k2>k1)后,k1和k2的值分别为
A)0和1 B)0和20 C)10和1 D)10和20
(18)有以下程序
#include <stdio.h>
main()
{
int a=1,b=0;
if (--a) b++;
else if(a==0) b+=2;
else b+=3;
printf("%d\n",b);
)
程序运行后的输出结果是
A)0 B)1 C)2 D)3
(19)下列条件语句中,输出结果与其他语句不同的是
A)if (a)printf("%d\n",x); else printf("%d\n",y);
B)if (a==0) printf("%d\n",y); else printf("%d\n",x);
C)if (a!=0) printf ("%d\n",x); else printf("%d\n",y);
D)if (a==0) printf("%d\n",x); else printf("%d\n",y);
(20)有以下程序
#include <stdio.h>
main()
{
int a=7;
while(a--);
printf("%d\n",a);
)
程序运行后的输出结果是
A)-1 B)0 C)1 D)7
(21)下列不能输出字符A的语句是(注:字符A和a的ASCIl码值分别为65和97)
A)printf("%c\n",'a'-32); B)printf("%d\n",'A');
C)printf("%c\n",65); D)print-f("%c\n",'B'-1);
(22)有以下程序(注:字符a的ASCIl码值为97)
#include <stdio.h>
main()
{
char *s={"abc"};
do
{ printf("%d",*%10);++s;
}while(*s);
)
程序运行后的输出结果是
A)abc B)789 C)7890 D)979899
(23)若有定义语句:double a,*p=&a;下列叙述中错误的是
A)定义语句中的*号是一个间址运算符
B)定义语句中的*号只是一个说明符
C)定义语句中的P只能存放double类型变量的地址
D)定义语句中,*p=&a把变量a的地址作为初值赋给指针变量p
(24)有以下程序
#include<stdio.h>
double f(double x)
{ return x*x+1;}
void main()
{
double a=0;
int i;
for (i=0;i<30;i+=10)
a+=f((double)i);
printf("%5.0f\n",a);
}
程序运行后的输出结果是
A)401 B)500 C)503 D)1404
(25)若有定义语句:int year=2019,*p=&year;,以下不能使变量year中的值增至2020的
语句是
A)*p+=1; B)( *p)++; C)++(*p); D)*p++;
(26)下列定义数组的语句中错误的是
A)int num[]={1,2,3,4,5,6};
B)int num[][3]={{1,2},3,4,5,6};
C)int num[2][4]=({1,2,{3,4},{5,6});
D)int num[][4]={1,2,3,4,5,6};
(27)有以下程序
#include <stdio.h>
void fun(int *p)
{ printf(“%d\n”,p[5]);}
main()
{ int a[10]={1,2,3,4,5,6,7,8,9,10};
fun(&a[3]);
)
程序运行后的输出结果是
A)5 B)6 C)8 D)9
(28)有以下程序
#include<stdio.h>
#define N 4
void fun(int a[][N],int b[])
{
int i;
for (i=0;i<N;i++)
b[i]=a[i][i]-a[i][N-1-i];
}
void main()
{
int x[N][N]={{1,2,3,4},{5,6,7,8},{9,10,11,12},{13,14,15,16}};
int y[N],i;
fun(x,y);
for (i=0;i<N;i++)
printf("%d,",y[i]);
printf("\n");
}
程序运行后的输出结果是
A)-12,-3,0,0, B)-3,-1,1,3,
C)0,1,2,3, D)-3,-3,-3,-3
(29)有以下函数
int fun(char *x,char *y)
{ int n=0;
while ((*x=*y)&&*x!='\0') {x++;y++;n++;}
return n:
)
函数的功能是
A)查找x和y所指字符串中是否有'\0'
B)统计x和y所指字符串中前面连续相同的字符个数
C)将y所指字符串赋给X所指存储空间
D)统计x和y所指字符串中相同的字符个数
(30)若有定义语句:char *s1="OK",*s2="ok";,以下选项中,能够输出"OK"的语句是
A)if(strcmp(s1,s2)=0) puts(s1); B)if(strcmp(s1,s2)!=0) puts(s2);
C)if(strcmp(s1,s2)=1) puts(s1); D)if(strcmp(s1,s2)!=0) puts(s1);
(31)以下程序的主函数中调用了在其前面定义的fun函数
main()
{ double a[15],k;
k=fun(a);
}
则以下选项中错误的fun函数首部是
A)double fun(double a[15]) B)double fun(double *A)
C)double fun(double a[]) D)double fun(double A)
(32)有以下程序
#include <stdio.h>
#include <string.h>
int main()
{
char a[5][10]={"china","beijing","you","tiananmen","welcome"};
int i,j; char t[10];
for(i=0;i<4;i++)
for(j=i+1;j<5;j++)
if (strcmp(a[i],a[j])>0)
{ strcpy(t,a[i]); strcpy(a[i],a[j]); strcpy(a[j],t); }
puts(a[3]);
return 0;
}
程序运行后的输出结果是
A)Beijing B)china C)welcome D)tiananmen
(33)有以下程序
#include <stdio.h>
int f(int m)
{ static int n=0;
n+=m:
return n;
}
main()
{ int n=0;
printf("%d,",f(++n));
printf("%d\n",f(n++));
}
程序运行后的输出结果是
A)1, 1 B)1,2 C)2,3 D)3,3
(34)有以下程序
#include <stdio.h>
main()
{ char ch [3][5]={"AAAA","BBB","CC"};
printf ("%s\n",ch[1]);
}
程序运行后的输出结果是
A)AAAA B)BBB C)BBBCC D)CC
(35)有以下程序
#include <stdio.h>
#include <string.h>
void fun(char *w,int m)
{
char s,*p1,*p2;
p1=w; p2=w+m-1;
while (p1<p2)
{ s=*p1; *p1=*p2; *p2=s; p1++; p2--;}
}
int main()
{
char a[]="123456";
fun(a,strlen(a));
puts(a);
return 0;
}
程序运行后的输出结果是
A)116611 B)123456 C)161616 D)654321
(36)有以下程序
#include <stdio.h>
#include <string.h>
typedef struct
{ char name[9]; char sex; int score[2];}STU;
STU fun(STU a)
{
STU b={"Zhao",'m',85,90};
int i;
strcpy(a.name,b.name);
a.sex=b.sex;
for (i=0;i<2;i++) a.score[i]=b.score[i];
return a;
}
int main()
{
STU c={"Qian",'f',95,92},d;
d=fun(c);
printf("%s,%c,%d,%d,",d.name,d.sex,d.score[0],d.score[1]);
printf("%s,%c,%d,%d,",c.name,c.sex,c.score[0],c.score[1]);
return 0;
}
程序运行后的输出结果是
A)Zhao,m,85,90,Qian,f,95,92
B)Zhao,m,85,90,Zha0,m,85,90
C)Qian,f,95,92,Qian,f,95,92
D)Qian,f,95,92,Zhao,m,85,90
(37)有以下程序
#include <stdio.h>
main()
{ struct node {int n;stmct node+next;} *p;
struct node x[3]={{2,x+l},{4,x+2},{6,NULL}};
p=x;
printf("%d,",p->n);
printf("%d\n",p->next->n);
}
程序运行后的输出结果是
A)2,3 B)2,4 C)3,4 D)4,6
(38)有以下程序
#include <stdio.h>
main()
{ int a=2,b;
b=a<<2;
printf("%d\n",b);
)
程序运行后的输出结果是
A)2 B)4 C)6 D)8
(39)下列选项中叙述错误的是
A)C程序函数中定义的赋有初值的静态变量,每调用一次函数,赋一次初值
B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内
C)C程序函数中定义的自动变量,系统不自动赋确定的初值
D)C程序函数的形参不可以说明为static型变量
(40)有以下程序
#include <stdio.h>
int main()
{
FILE *fp;
int k,n,i,a[6]={1,2,3,4,5,6};
fp=fopen("d2.dat","w");
for (i=0; i<6; i++) fprintf(fp,"%d\n",a[i]);
fclose(fp);
fp=fopen("d2.dat","r");
for (i=0; i<3; i++) fscanf(fp,"%d%d",&k,&n);
fclose(fp);
printf("%d,%d\n",k,n);
return 0;
}
程序运行后的输出结果是
A)1,2 B)3,4 C)5,6 D)123,456
二、程序填空题(18分)
下面程序中函数fun的功能是检查一个字符串是否是回文,当字符串是回文时,函数返回字符串yes!;否则函数返回字符串no!,并在主函数中输出。所谓回文即正向与反向的拼写都一样,例如:adgda。
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。
注意:部分源程序在文件BLANK1.C中。不得增行或删行,也不得更改程序的结构。
试题程序:
#include <stdio.h>
#include <string.h>
/**********found**********/
___1___ fun(char *str)
{
char *p1,*p2;
unsigned int i,t=0;
p1=str;
/**********found**********/
p2=___2___;
for (i=0;i<=strlen(str)/2;i++)
if(*p1++!=*p2--)
{ t=1; break; }
/**********found**********/
if (___3___) return ("yes!");
else return ("no!");
}
int main()
{
char str[50];
printf("Input:");
scanf("%s",str);
printf("%s\n",fun(str) );
return 0;
}
三、程序修改题(18分)
下列给定程序中,函数fun的功能是:根据下面的公式求π的近似值。形参n给出了公式右边的项数,如n=4表示π/4=1-1/3+1/5-1/7。例如,给定实参项数的值为5000,则程序运行后,输出为PI = 3.1413927。

请改正程序中的错误,使它能得出正确的结果。注意:部分源程序在文件MODI1.C中,不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
double fun(int n)
{
double pi = 0.0;
int i,f=1;
for (i=1;i<=n;i++)
{
/*************found**************/
pi = pi + f/(2*i-1);
f = -f;
}
/*************found**************/
return pi;
}
int main()
{
printf("PI = %.7lf\n",fun(5000));
return 0;
}
四、程序设计题(24分)
请编写函数int fun(int n),其功能是判断正整数n是否素数,若是返回“1”,否则,返回“0”。所谓素数是指一个大于1的自然数,该数除了1和它本身以外不再有其他的因数。例如,2、3、5、7等数是素数,而4、6、8、9等数不是素数。
注意:部分源程序在文件PROG1.C中。请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
试题程序:
#include <stdio.h>
#include <math.h>
int fun(int n)
{
}
int main()
{
int i;
printf("%4d",2);
for (i=3;i<100;i=i+2)
if (fun(i)==1)
printf("%4d",i);
printf("\n");
return 0;
}
一、选择题
( 1)~(10) :DCBAB DADBA
(11)~(20) :CCDCA CBCDA
(21)~(30) :BBACD CDBBD
(31)~(40) :DCBBD ABDAC
二、程序填空题
(1) char *
(2) str+strlen(str)-1
(3) t==0或 ! t
三、程序改错题
(1) pi = pi + 1.0*f/(2*i-1);
(2) return 4*pi;
四、程序设计题
int i,k;
k=(int)sqrt(1.0*n);
for (i=2;i<=k;i++)
if (n%i==0) break;
if (i>k)
return 1;
else
return 0;
参考答案:我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou
这里是Ruby新手。完成一些练习后碰壁了。练习:计算一系列成绩的字母等级创建一个方法get_grade来接受测试分数数组。数组中的每个分数应介于0和100之间,其中100是最大分数。计算平均分并将字母等级作为字符串返回,即“A”、“B”、“C”、“D”、“E”或“F”。我一直返回错误:avg.rb:1:syntaxerror,unexpectedtLBRACK,expecting')'defget_grade([100,90,80])^avg.rb:1:syntaxerror,unexpected')',expecting$end这是我目前所拥有的。我想坚持使用下面的方法或.join,
几个月前,我读了一篇关于rubygem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:
?博客主页:https://xiaoy.blog.csdn.net?本文由呆呆敲代码的小Y原创,首发于CSDN??学习专栏推荐:Unity系统学习专栏?游戏制作专栏推荐:游戏制作?Unity实战100例专栏推荐:Unity实战100例教程?欢迎点赞?收藏⭐留言?如有错误敬请指正!?未来很长,值得我们全力奔赴更美好的生活✨------------------❤️分割线❤️-------------------------
嗨~大家好,这里是可莉!今天给大家带来的是7个C语言的经典基础代码~那一起往下看下去把【程序一】打印100到200之间的素数#includeintmain(){ inti; for(i=100;i 【程序二】输出乘法口诀表#includeintmain(){inti;for(i=1;i 【程序三】判断1000年---2000年之间的闰年#includeintmain(){intyear;for(year=1000;year 【程序四】给定两个整形变量的值,将两个值的内容进行交换。这里提供两种方法来进行交换,第一种为创建临时变量来进行交换,第二种是不创建临时变量而直接进行交换。1.创建临时变量来
项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU
我对如何计算通过{%assignvar=0%}赋值的变量加一完全感到困惑。这应该是最简单的任务。到目前为止,这是我尝试过的:{%assignamount=0%}{%forvariantinproduct.variants%}{%assignamount=amount+1%}{%endfor%}Amount:{{amount}}结果总是0。也许我忽略了一些明显的东西。也许有更好的方法。我想要存档的只是获取运行的迭代次数。 最佳答案 因为{{incrementamount}}将输出您的变量值并且不会影响{%assign%}定义的变量,我
给定一个nxmbool数组:[[true,true,false],[false,true,true],[false,true,true]]有什么简单的方法可以返回“该列中有多少个true?”结果应该是[1,3,2] 最佳答案 使用转置得到一个数组,其中每个子数组代表一列,然后将每一列映射到其中的true数:arr.transpose.map{|subarr|subarr.count(true)}这是一个带有inject的版本,应该在1.8.6上运行,没有任何依赖:arr.transpose.map{|subarr|subarr.in
假设我在Store的模型中有这个非常简单的方法:defgeocode_addressloc=Store.geocode(address)self.lat=loc.latself.lng=loc.lngend如果我想编写一些不受地理编码服务影响的测试脚本,这些脚本可能已关闭、有限制或取决于我的互联网连接,我该如何模拟地理编码服务?如果我可以将地理编码对象传递到该方法中,那将很容易,但我不知道在这种情况下该怎么做。谢谢!特里斯坦 最佳答案 使用内置模拟和stub的rspecs,你可以做这样的事情:setupdo@subject=MyCl