一、选择题(每小题1分,共40分)
(1)下列叙述中正确的是
A)对长度为n的有序链表进行查找,最坏情况下需要的比较次数为n
B)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(n/2)
C)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(log2n)
D)对长度为n的有序链表进行对分查找,最坏情况下需要的比较次数为(nlog2n)
(2)算法的时问复杂度是指
A)算法的执行时间
B)算法所处理的数据量
C)算法程序中的语句或指令条数
D)算法在执行过程中所需要的基本运算次数
(3)软件按功能可以分为:应用软件、系统软件和支撑软件(或工具软件)。下面属于系统软件的是
A)编辑软件 B)操作系统 C)教务管理系统 D)浏览器
(4)软件(程序)调试的任务是
A)诊断和改正程序中的错误 B)尽可能多地发现程序中的错误
C)发现并改正程序中的所有错误 D)确定程序中错误的性质
(5)数据流程图(DFD图)是
A)软件概要设计的工具 B)软件详细设计的工具
C)结构化方法的需求分析工具 D)面向对象方法的需求分析工具
(6)软件生命周期可分为定义阶段,开发阶段和维护阶段。详细设计属于
A)定义阶段 B)开发阶段 C)维护阶段 D)上述三个阶段
(7)数据库管理系统中负责数据模式定义的语言是
A)数据定义语言 B)数据管理语言 C)数据操纵语言 D)数据控制语言
(8)在学生管理的关系数据库中,存取一个学生信息的数据单位是
A)文件 B)数据库 C)字段 D)记录
(9)数据库设计中,用E-R图来描述信息结构但不涉及信息在计算机中的表示,它属于数据库设计的
A)需求分析阶段 B)逻辑设计阶段 C)概念设计阶段 D)物理设计阶段
(10)有两个关系R和T如下:

则由关系K得到关系T的操作是
A)选择 B)投影 C)交 D)并
(11)以下叙述正确的是
A)C语言程序是由过程和函数组成的
B)C语言函数可以嵌套调用,例如:fun(fun(x))
C)C语言函数不可以单独编译
D)C语言中除了main函数,其他函数不可作为单独文件形式存在
(12)以下关于C语言的叙述中正确的是
A)C语言中的注释不可以夹在变量名或关键字的中间
B)C语言中的变量可以在使用之前的任何位置进行定义
C)在C语言算术表达式的书写中,运算符两侧的运算数类型必须一致
D)C语言的数值常量中夹带空格不影响常量值的正确表示
(13)以下C语言用户标识符中,不合法的是
A)_1 B)AaBc C)a_b D)a--b
(14)若有定义:double a=22;int i=0,k=18;,则不符合C语言规定的赋值语句是
A)a= i++; B)i=(a+k)<=(i+k); C)i=a%11; D)i=!a;
(15)有以下程序
#include <stdio.h>
int main()
{ char a,b,c,d;
scanf(“%c%c”,&a,&b);
c=getchar(); d=getchar();
printf(“%c%c%c%c\n”,a,b,c,d);
return 0;
}
当执行程序时,按下列方式输入数据(从第1列开始,<CR>代表回车,注意:回车也是一个字符)
12<CR>
34<CR>
则输出结果是
A) 12 B) 1234 C)12 D)12
3 34
(16)以下关于C语言数据类型使用的叙述中错误的是
A)若要准确无误差的表示自然数,应使用整数类型
B)若要保存带有多位小数的数据,应使用双精度类型
C)若要处理如“人员信息”等含有不同类型的相关数据,应自定义结构体类型
D)若只处理“真”和“假”两种逻辑值,应使用逻辑类型
(17)若a是数值类型,则逻辑表达式(a==1)||(a!=1)的值是
A) 0 B) 1
C)2 D)不知道a的值,不能确定
(18)以下选项中与if (a==1)a=b; else a++;语句功能不同的switch语句是
A)switch(a) B)switch(a==1)
{ case 1:a=b;break; { case 0:a=b;break;
default:a++; case 1:a++;
} }
C)switch(a) D)switch(a==1)
{ default:a++;break; { case 1:a=b;break;
case 1:a=b; case 0:a++;
} }
(19)有如下嵌套的if语句
if (a<b)
if (a<c) k=a;
else k=c;
else
if (b<c) k=b;
else k=c;
以下选项中与上述if语句等价的语句是
A)k=(a<b)?a:b; k=(b<c)?b:c; B)k=(a<b)?a:b; k=(a<c)?a:c;
C)k=(a<b)?((a<c)?a:c):((b<c)?b:c); D) k=(a<b)?((b<c)?a:b):((b>c)?b:c);
(20)有以下程序
#include <stdio.h>
int main()
{
int i,j,m=1;
for (i=1;i<3;i++)
{
for(j=3;j>0;j--)
{
if(i*j>3)break;
m*=i*j;
}
}
printf("m=%d\n",m);
return 0;
}
程序运行后的输出结果是
A)m=2 B)m=4 C)m=5 D)m=6
(21)有以下程序
#include <stdio.h>
int main()
{ int a=1;b=2;
for (;a<8;a++) { b+=a; a+=2;}
printf(“%d,%d\n”,a,b);
return 0;
}
程序运行后的输出结果是
A) 7,11 B)8,11 C) 9,18 D)10,14
(22)有以下程序
#include <stdio.h>
int main()
{ int k=011;
printf(“%d\n”,k++);
return 0;
}
程序运行后的输出结果是
A) 9 B) 10 C) 11 D) 12
(23)下列语句组中,正确的是
A)char *s; s=“Olympic”; B)char s[7]; s=“Olympic”;
C)char *s; s={“Olympic”}; D)char s[7]; s={“Olympic”};
(24)以下关于return语句的叙述中正确的是
A)一个自定义函数中必须有一条return语句
B)一个自定义函数中可以根据不同情况设置多条return语句
C)定义成void类型的函数中可以有带返回值的return语句
D)没有return语句的自定义函数在执行结束时不能返回到调用处
(25)下列选项中,能正确定义数组的语句是
A)int num[0..2008]; B)int num[]; C)int N=2008; D)#define N 2008
int num[N]; int num[N];
(26)有以下程序
#include <stdio.h>
void fun(char *c,int d)
{ *c=*c+1;d=d+1;
printf(“%c,%c,”,*c,d);
}
int main()
{ char b='a',a='A';
fun(&b,a);
printf(“%c,%c\n”,b,a);
return 0;
}
程序运行后的输出结果是
A)b,B,b,A B)b,B,B,A C)a,B,B,a D)a,B,a,B
(27)若有定义int (*Pt)[3];,则下列说法正确的是
A)定义了基类型为int的三个指针变量
B)定义了基类型为int的具有三个元素的指针数组pt
C)定义了一个名为*pt、具有三个元素的整型数组
D)定义了一个名为pt的指针变量,它可以指向每行有三个整数元素的二维数组
(28)设有定义double a[10],*s=a;,以下能够代表数组元素a[3]的是
A)(*s)[3] B)*(s+3) C)*s[3] D)*s+3
(29)有以下程序
#include <stdio.h>
int main()
{ int a[5]={1,2,3,4,5},b[5]={0,2,1,3,0},i,s=0;
for (i=0; i<5; i++) s=s+a[b[i]];
printf("%d\n",s);
return 0;
}
程序运行后的输出结果是
A)6 B)10 C)11 D)15
(30)有以下程序
#include <stdio.h>
int main()
{
int b[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;
for (i=0; i<3; i++)
for (j=0; j<=i; j++)
t+=b[i][b[j][i]];
printf("%d\n",t);
return 0;
}
程序运行后的输出结果是
A)1 B)3 C)4 D)9
(31)若有以下定义和语句
char s1[10]=“abcd!”,*s2=“\n123\\”;
printf(“%d %d\n”, strlen(s1),strlen(s2));
则输出结果是
A)5 5 B) 5 7 C) 10 5 D) 10 7
(32)有以下程序
#include <stdio.h>
#define N 8
void fun(int *x,int i)
{*x=*(x+i);}
int main()
{ int a[N]={1,2,3,4,5,6,7,8},i;
fun(a,2);
for(i=0;i<N/2;i++)
{ printf(“%d”,a[i]);}
printf(“\n”);
return 0;
}
程序运行后的输出结果是
A)1234 B)1313 C)2234 D)3234
(33)有以下程序
#include <stdio.h>
int f(int t[],int n)
{
if (n>0) return t[n-1]+f(t,n-1);
else return 0;
}
int main()
{
int a[4]={1,2,3,4},s;
s=f(a,4);
printf("%d\n",s);
return 0;
}
程序运行后的输出结果是
A)4 B)10 C)14 D)16
(34)有以下程序
#include <stdio.h>
int fun()
{
static int x=1;
x*=2;
return x;
}
int main()
{
int i,s=0;
for (i=1; i<=2;i++)
s=fun();
printf("%d\n",s);
return 0;
}
程序运行后的输出结果是
A)0 B)1 C)4 D)8
(35)有以下程序
#include <stdio.h>
#define SUB(a) (a)-(a)
int main()
{
int a=2,b=3,c=5,d;
d=SUB(a+b)*c;
printf("%d\n",d);
return 0;
}
程序运行后的输出结果是
A) -20 B)-12 C) 0 D)10
(36)设有定义:
struct complex
{ int real,unreal;} data1={1,8},data2;
则以下赋值语句中错误的是
A)data2=data1; B)data2={2,6};
C)data2.real=data1.real; D)data2.real=data1.unreal;
(37)有以下程序
#include <stdio.h>
#include <string.h>
struct A
{
int a;
char b[10];
double c;
};
void f(struct A t)
{
t.a=1002;
strcpy(t.b,"ChangRong");
t.c=1202.0;
}
int main()
{
struct A a={1001,"ZhangDa",1098.0};
f(a);
printf("%d,%s,%6.1f\n",a.a,a.b,a.c);
return 0;
}
程序运行后的输出结果是
A)1001,zhangDa,1098.0 B)1002,changRong,1202.0
C)1001,ehangRong,1098.0 D)1002,ZhangDa,1202.0
(38)有以下定义和语句
struct workers
{
int num;
char name[20];
struct
{ int day,month,year;} S;
};
struct workers w,*pw;
pw=&w;
能给w中year成员赋1980的语句是
A)*pw.year=1980; B)w.year=1980;
C)pw->year=1980; D)w.s.year=1980;
(39)有以下程序
#include <stdio.h>
int main()
{ int a=2,b=2,c=2;
printf(“%d\n”,a/b&c);
return 0;
}
程序运行后的输出结果是
A)0 B)1 C)2 D)3
(40)有以下程序
#include <stdio.h>
int main()
{ FILE *fp;char str[10];
fp=fopen(“myfile.dat”,”w”);
fputs(“abc”,fp); fclose(fp);
fpfopen(“myfile.data”,”a++”);
fprintf(fp,”%d”,28);
rewind(fp);
fscanf(fp,”%s”,str); puts(str);
fclose(fp);
return 0;
}
程序运行后的输出结果是
A)abc B) 28c
C) abc28 D)因类型不一致而出错
二、程序填空题(18分)
给定程序中,函数fun的功能是建立一个N×N的矩阵。矩阵元素的构成规律是:最外层元素的值全部为1;从外向内第2层元素的值全部为2;第3层元素的值全部为3,……依此类推。例如,若N=5,生成的矩阵为:
1 1 1 1 1
1 2 2 2 1
1 2 3 2 1
1 2 2 2 1
1 1 1 1 1
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。注意:部分源程序在文件BLANK1.C中。不得增行或删行,也不得更改程序的结构!
试题程序:
#include <stdio.h>
#define N 7
/**********found**********/
void fun(int (*a)__1__)
{ int i,j,k,m;
if(N%2==0) m=N/2 ;
else m=N/2+1;
for(i=0; i<m; i++) {
/**********found**********/
for(j=__2__; j<N-i; j++)
a[i][j]=a[N-i-1][j]=i+1;
for(k=i+1; k<N-i; k++)
/**********found**********/
a[k][i]=a[k][N-i-1]=__3__;
}
}
int main()
{ int x[N][N]={0},i,j;
fun(x);
printf("The result is:\n");
for(i=0; i<N; i++)
{
for(j=0; j<N; j++) printf("%3d",x[i][j]);
printf("\n");
}
return 0;
}
三、程序修改题(18分)
下列给定程序中,函数fun的功能是:求k!(k<13),所求阶乘的值作为函数值返回。例如,若k=10,则应输出3628800。
请改正程序中的错误,使它能得出正确的结果。
注意:部分源程序在文件MODI1.C中,不要改动main函数,不得增行或删行,也不得更改程序的结构!
试题程序:
#include <conio.h>
#include <stdio.h>
long fun(int k)
{
/*************found**************/
if k>1
return(k*fun(k-1));
/*************found**************/
return 0;
}
void main()
{
int k=10;
printf("%d!=%ld\n ",k,fun(k));
}
四、程序设计题(24分)
编写一个函数,该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为"asd asasdfg asd as zx67 asd mklo",子字符串为"as",则应当输出6。
注意:部分源程序在文件PROG1.C中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。
试题程序:
#include <conio.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int fun(char *str, char *substr)
{
}
void main()
{
FILE *wf;
char str[81],substr[3];
int n;
system("CLS");
printf("输入主字符串: ");
gets(str);
printf("输入子字符串: ");
gets(substr);
puts(str);
puts(substr);
n=fun(str,substr);
printf("n=%d\n ",n);
/******************************/
wf=fopen("out.dat","w");
n=fun("asd asasdfg asd as zx67 asd mklo","as");
fprintf(wf,"%d",n);
fclose(wf);
/*****************************/
}
一、选择题
( 1)~(10) : A D B A C B A D A A
(11)~(20) : B B D C C D B B C D
(21)~(30) : D A A B D A D B C D
(31)~(40) : A D B C A B A D A C
二、程序填空题
(1) [N]
(2) i
(3) i+1
三、程序改错题
(1) if (k>1)
(2) return 1;
四、程序设计题
int i,j=0;
for (i=0; str[i+1]!='\0'; i++)
if (str[i]==substr[0] && str[i+1]==substr[1])
j++;
return j;
参考答案:我正在寻找执行以下操作的正确语法(在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