軟通動力C語言筆試題
1、局部變量能否和全局變量重名?
答:能,局部會屏蔽全局。要用全局變量,需要使用 ":: "
局部變量可以與全局變量同名,在函數內引用這個變量時,會用到同名的局部變量,而不會用到全局變量。對于有些編譯器而言,在同一個函數內可以定義多個同名的局部變量,比如在兩個循環體內都定義一個同名的局部變量,而那個局部變量的作用域就在那個循環體內。
2、如何引用一個已經定義過的全局變量?
答:extern
可以用引用頭文件的方式,也可以用extern關鍵字,如果用引用頭文件方式來引用某個在頭文件中聲明的全局變理,假定你將那個變寫錯了,那么在編譯期間會報錯,如果你用extern方式引用時,假定你犯了同樣的錯誤,那么在編譯期間不會報錯,而在連接期間報錯。
3、全局變量可不可以定義在可被多個.C文件包含的頭文件中?為什么?
答:可以,在不同的C文件中以static形式來聲明同名全局變量。
可以在不同的C文件中聲明同名的全局變量,前提是其中只能有一個C文件中對此變量賦初值,此時連接不會出錯
4、語句for( ;1 ;)有什么問題?它是什么意思?
答:和while(1)相同。
5、do……while和while……do有什么區別?
答:前一個循環一遍再判斷,后一個判斷以后再循環
6、請寫出下列代碼的輸出內容
#include
main()
{
int a,b,c,d;
a=10;
b=a++;
c=++a;
d=10*a++;
printf( "b,c,d:%d,%d,%d ",b,c,d);
return 0;
}
答:10,12,120
7、static全局變量與普通的全局變量有什么區別?static局部變量和普通局部變量有什么區別?static函數與普通函數有什么區別?
全局變量(外部變量)的說明之前再冠以static 就構成了靜態的全局變量。全局變量本身就是靜態存儲方式, 靜態全局變量當然也是靜態存儲方式。 這兩者在存儲方式上并無不同。這兩者的區別雖在于非靜態全局變量的作用域是整個源程序, 當一個源程序由多個源文件組成時,非靜態的全局變量在各個源文件中都是有效的。 而靜態全局變量則限制了其作用域, 即只在定義該變量的源文件內有效, 在同一源程序的其它源文件中不能使用它。由于靜態全局變量的作用域局限于一個源文件內,只能為該源文件內的函數公用, 因此可以避免在其它源文件中引起錯誤。
從以上分析可以看出, 把局部變量改變為靜態變量后是改變了它的存儲方式即改變了它的生存期。把全局變量改變為靜態變量后是改變了它的作用域, 限制了它的使用范圍。
static函數與普通函數作用域不同。僅在本文件。只在當前源文件中使用的`函數應該說明為內部函數(static),內部函數應該在當前源文件中說明和定義。對于可在當前源文件以外使用的函數,應該在一個頭文件中說明,要使用這些函數的源文件要包含這個頭文件
static全局變量與普通的全局變量有什么區別:static全局變量只初使化一次,防止在其他文件單元中被引用;
static局部變量和普通局部變量有什么區別:static局部變量只被初始化一次,下一次依據上一次結果值;
static函數與普通函數有什么區別:static函數在內存中只有一份,普通函數在每個被調用中維持一份拷貝
8、程序的局部變量存在于(堆棧)中,全局變量存在于(靜態區 )中,動態申請數據存在于( 堆)中。
9、設有以下說明和定義:
typedef union {long i; int k[5]; char c;} DATE;
struct data { int cat; DATE cow; double dog;} too;
DATE max;
則語句 printf( "%d ",sizeof(struct date)+sizeof(max));的執行結果是:___52____
答:DATE是一個union, 變量公用空間. 里面最大的變量類型是int[5], 占用20個字節. 所以它的大小是20
data是一個struct, 每個變量分開占用空間. 依次為int4 + DATE20 + double8 = 32.
所以結果是 20 + 32 = 52.
當然...在某些16位編輯器下, int可能是2字節,那么結果是 int2 + DATE10 + double8 = 20
10、隊列和棧有什么區別?
隊列先進先出,棧后進先出
11、寫出下列代碼的輸出內容
#include
int inc(int a)
{
return(++a);
}
int multi(int*a,int*b,int*c)
{
return(*c=*a**b);
}
typedef int(FUNC1)(int in);
typedef int(FUNC2) (int*,int*,int*);
void show(FUNC2 fun,int arg1, int*arg2)
{
INCp= &inc;
int temp =p(arg1);
fun( &temp,&arg1, arg2);
printf( "%d\n ",*arg2);
}
main()
{
int a;
show(multi,10, &a);
return 0;
}
答:110
11、請找出下面代碼中的所以錯誤
說明:以下代碼是把一個字符串倒序,如“abcd”倒序后變為“dcba”
1、#include "string.h "
2、main()
3、{
4、 char*src= "hello,world ";
5、 char* dest=NULL;
6、 int len=strlen(src);
7、 dest=(char*)malloc(len);
8、 char* d=dest;
9、 char* s=src[len];
10、 while(len--!=0)
11、 d++=s--;
12、 printf( "%s ",dest);
13、 return 0;
14、}
答:
方法1:
int main()
{
char* src = "hello,world ";
int len = strlen(src);
char* dest = (char*)malloc(len+1);//要為\0分配一個空間
char* d = dest;
char* s = &src[len-1];//指向最后一個字符
while( len-- != 0 )
*d++=*s--;
*d = 0;//尾部要加\0
printf( "%s\n ",dest);
free(dest);// 使用完,應當釋放空間,以免造成內存匯泄露
return 0;
}
方法2:
#include
#include
main()
{
char str[]= "hello,world ";
int len=strlen(str);
char t;
for(int i=0; i {
t=str[i];
str[i]=str[len-i-1]; str[len-i-1]=t;
}
printf( "%s ",str);
return 0;
}
12。對于一個頻繁使用的短小函數,在C語言中應用什么實現,在C++中應用什么實現?
答案:c用宏定義,c++用inline
13。軟件測試都有那些種類?
答案:黑盒:針對系統功能的測試 白合:測試函數功能,各函數接口
14。確定模塊的功能和模塊的接口是在軟件設計的那個隊段完成的?
答案:概要設計階段
15。enum string
{
x1,
x2,
x3=10,
x4,
x5,
}x;
問x;
答案:取值在0。1。10。11。12中的一個
16。unsigned char *p1;
unsigned long *p2;
p1=(unsigned char *)0x801000;
p2=(unsigned long *)0x810000;
請問p1+5= ;
p2+5= ;
答案:801005; 810014。不要忘記了這個是16進制的數字,p2要加20變為16進制就是14
選擇題:
1.Ethternet鏈接到Internet用到以下那個協議?
A.HDLC;B.ARP;C.UDP;D.TCP;E.ID
2.屬于網絡層協議的是:
A.TCP;B.IP;C.ICMP;D.X.25
3.Windows消息調度機制是:
A.指令隊列;B.指令堆棧;C.消息隊列;D.消息堆棧;
答案:b,a,c
二找錯題:
1.請問下面程序有什么錯誤?
int a[60][250][1000],i,j,k;
for(k=0;k<=1000;k++)
for(j=0;j<250;j++)
for(i=0;i<60;i++)
a[i][j][k]=0;
答案:把循環語句內外換一下
2。以下是求一個數的平方的程序,請找出錯誤:
#define SQUARE(a) ((a)*(a))
int a=5;
int b;
b=SQUARE(a++);
答案:這個沒有問題,s(a++),就是((a++)×(a++))唯一要注意的就是計算后a=7了
3。typedef unsigned char BYTE
int examply_fun(BYTE gt_len; BYTE *gt_code)
{
BYTE *gt_buf;
gt_buf=(BYTE *)MALLOC(Max_GT_Length);
......
if(gt_len>Max_GT_Length)
{
return GT_Length_ERROR;
}
.......
}
答案:要釋放內存
問答題:
1.IP Phone的原理是什么?
答案:IPV6
2.TCP/IP通信建立的過程怎樣,端口有什么作用?
答案:三次握手,確定是哪個應用程序使用該協議
1. 用宏定義寫出swap(x,y)
#define swap(x, y)\
x $denghao$ x + y;\
y $denghao$ x - y;\
x $denghao$ x - y;
2.數組a[n],存放了1至n-1個數,其中某個數重復一次。寫一個函數,找出被重復的數字.時間復雜度必須為o(n)函數原型:
int do_dup(int a[],int n)
3 一語句實現x是否為2的若干次冪的判斷
int i $denghao$ 512;
cout << boolalpha << ((i & (i - 1)) ? false : true) << endl;
4.unsigned int intvert(unsigned int x,int p,int n)實現對x的進行轉換,p為起始轉化位,n為需要轉換的長度,假設起始點在右邊.如x$denghao$0b0001 0001,p$denghao$4,n$denghao$3轉換后x$denghao$0b0110 0001
unsigned int intvert(unsigned int x,int p,int n){
unsigned int _t $denghao$ 0;
unsigned int _a $denghao$ 1;
for(int i $denghao$ 0; i < n; ++i){
_t |$denghao$ _a;
_a $denghao$ _a << 1;
}
_t $denghao$ _t << p;
x ^$denghao$ _t;
return x;
}
一. 選擇題
1. 在關系數據庫德詢問優化中,事先處理文件,如排序、建立索引的目的是:()
A.優化表達式 B。減少中間結束 C。擴大緩沖數據 D。 減少掃描文件的時間
2.進程是操作系統中的一個重要概念。進程是一個具有一定獨立功能的程序在某個數據集合上的一次(A);進程是一個(B)的概念,而程序是一個(C)的概念;進程的最基本狀態有(D)。在一個單處理機,若有6個用戶進程,在非管態的某一時刻,處于就緒狀態的用戶進程最多有(E)個。
供選擇的答案
A: (1)單獨操作 (2)關聯操作 (3) 進行活動 (4)并發活動
B:(1)靜態 (2)動態 (3)邏輯 (4) 物
C:(1)物理 (2)邏輯 (3)動態 (4)靜態
D:(1)就緒、運行、隱蔽 (2)停止、就緒、運行 (3)運行、就緒、阻塞
(4)就緒、車消、運行
E: (1) 5 (2) 6 (3) 1 (4) 4
3. 有以下幾個條件成立:( )
(1)如果小王是工人 ,那么小張不是醫生
(2)或者小李是工人,或者小王是工人
(3)如果小張不是醫生,那么小趙不是學生
(4)或者小趙是學生,或者小周不是經理
以下哪項如果為真,可得出“小李是工人”的結論?
(A) 小周不是經理
(B) 小王是工人
(C) 小趙不是學生
(D) 小周是經理
二.簡答題
1.下面列舉的是常用的排序方法:直接插入排序,二分法插入排序,起泡排序,快速排序,直接選擇排序,堆排序,歸并排序。試問,哪些排序方法是穩定的?
答:(期待您的高見)
2. 對序列(49,38,65,97,76,27,13,50)采用快速排序法進行排序,以序列的第一個元素為基準元素得到的劃分結果是什么?
答:
3. 請仔細閱讀下面的SQL,判斷其是否有錯誤,如果有錯誤,請說明錯誤在哪里。
Select id , name ,age ,count (*)
From table_name
Where name like “ %s%”
Group by name
4. 請用面向對象分析的方法,分析“我用電腦寫程序”這句話的對象、屬性和方法。
三 問答題
電影《達芬奇密碼》中講到了一個非常有意思的數字序列---菲波拉契序列。請用任意計算機語言實現一段小程序,該程序在屏幕上輸出1到1000之間的非波拉契序列。
非波拉契序列:1,1,2,3,5,8,13,21,34,……
要求:用程序描述 核心算法。語言不限。
1. C++中如何阻止一個類被實例化?
2. 一般在什么時候構造函數被聲明成private呢?
3. 什么時候編譯器會生成默認的copy constructor呢?
4. 如果你已經寫了一個構造函數,編譯器還會生成copy constructor嗎?
5. struct和class有什么區別?
答:默認的訪問級別不同,struct是public,class是private
6. 沒有別的不同了嗎?
7. 為什么說如果一個類作為基類,則它的析構函數要聲明成virtual的?
8. inline的函數和#define有什么區別?
9. inline是什么意思?
10. 那你說說什么時候會真的被inline,什么時候不會呢?
11. 如果把一個類的成員函數寫在類的聲明中是什么意思?
12. public繼承和private繼承有什么架構上的區別?
13. 在多繼承的時候,如果一個類繼承同時繼承自class A和class B,而class A和
B中都有一個函數叫foo(),如何明確的在子類中指出override哪個父類的foo()?
14. 虛擬繼承的語法是什么?
15. 部分模版特例化
1.什么是平衡二叉樹?編寫一個刪除平衡二叉樹的程序?
2.寫一個程序,求有向有權圖兩點之間的最小權?
3.根據你的理解,寫出Cstring類的構造函數和析構函數?
4.使用C語言實現對ini文件的訪問,使程序可以對int,double,字符串類進行讀寫。
5.n×n個方格(n為任意整數),定義若兩個格有公共邊則稱兩個格相鄰,F將 個格中的N個格子圖黑,使每個格子都與黑格子相鄰。試編程,使N最小。
1
#define pi 3.14
#define Area(R) pi*R*R
main()
{
int r1=5,r2=2;
double s=0;
s=Area(r1-r2);
printf("The area is %f",s);
}
求結果
2
函數 int compare(int a,int b),定義為該函數的函數指針P:為_______________
3
#include
void sub(char*s,int num)
{
int i ,j=num;
char t;
while(j-->1)
{
for(i=0;i{
if(s[i]{
t=s[i];
s[i]=s[i+1];
s[i+1]=t;
}
}
}
}
main()
{
char*s="CEAeded";
sub(s,6);
printf("%s\n",s)
}
求結果
4
交換兩個變量的值,不使用第三個變量,即a=3,b=5交換
后b=3,a=5
unsigned char a=3,b=5;
5
#define N 100
void GetMemory1(char*p)
{
p=(char*)malloc(sizeof(char)*N);
strcpy(p,"Have a good day!");
}
char*GetMemory2(void)
{
char p[]="Have a good day!";
return p;
}
void main(void)
{
char*str1=NULL,*str2=NULL;
GetMemory1(str1);
GetMemory2(str2);
printf("\nstr1:%s",str1);
printf("\nstr2:%s",str2);
6
構造N個結點的單鏈表返回鏈表頭指針,要求鏈表中各結點順序
與結點數據輸入順序相反,例如輸入1,2,3,4,5,形成的鏈表為
head->5 4 3 2 1 ,補充程序
#define N 10
typedef struct Node
{
int data;
struct Node*next;
}NODE;
int Get_Data(int i);定義省略
Node*Create_u()
{
int i;
NODE*p,*Head=NULL;
for(i=0;i{
VP=New NODE;
P->Data=Get_Data(i);
________________;
________________;
}
return Head;
}
7
N個結點鏈表,每個結點中存放一個字符,判斷鏈表存放的字符是否
中心對稱,即a b c c b a或a b c b a,補充程序
typedef struct Node
{
int data;
struct Node*next;
}NODE;
bool Is_symmeic(NODE*head,*int n)
{
char D[N];
int i,d;
__________;
for(i=0;i{
D[i]=head->data;
head=head->next;
}
if(__________)
{
head=head->next;
}
while(head)
{
_______________;
if(D[i]!=head->data)
{
return false;
}
head=head->next;
}
return true;
}
8
str中只含有大寫和小寫字母函數change_move(char*str)將字符串中大寫改成*并
移到前面小寫后返回*的個數
如AabBdcYY改為*****abd,返回5
int chang_move(char*str)
{
int len,i,curstr=-1;
len=strlen(str);
for(i=len-1;i>=0;i--)
{
if(str[i]>='A'&&str[i]<='Z')
{
str[i]='*';
if(cursor==-1)
{
cursor=i;
}
else if(cursor>i)
{
_____________;
str[i]='*';
_____________;
}
}
return____________;
}
9
求兩個字符串的第一個公共子串,并返回該子串
如:"a b c d e f g e h i" "a a c d e f * * g e h i"
第一個為"c d e f";不許用strcmp()
char*Maxf(char*str1,char*str2)
{
}
【軟通動力C語言筆試題】相關文章:
C語言基礎筆試題12-27
C語言筆試題集錦12-27
外企C語言筆試題12-25
C語言筆試題回憶12-25
C語言筆試題總結12-25
東軟C/C++筆試題及參考答案11-14
c語言常見筆試題總結12-25
C語言常用筆試題12-24
華為C語言招聘筆試題目07-26
上海貝爾c語言筆試題07-03