當前位置:首頁 » 編程語言 » c語言期末編程及輸出結果例題
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

c語言期末編程及輸出結果例題

發布時間: 2022-05-22 22:53:10

c語言期末考試題目 求解

1.構造函數完成對象單元的初始化,析構函數釋放動態創建的單元
2.this 指針是一個隱性指針,指向當前創建的對象
3.重載函數函數名相同,返回值,參數個數及參數類型不同,是實現多態的一中方式,而虛函數只是多了具virtual來修飾,其他的函數原型相同
1、輸入一個整數,判斷是奇數還是偶數,並輸出結果。
int main()
{
int m;
cout<<"輸入一個整數"<<endl;
cin>>m;
if(m%2) cout<<"該數是奇數"<<endl;
else cout<<"該數是偶數"<<endl;
return 0;
}
2、編寫程序求1!+2!+3!+……..+20!的值。
int main()
{
int i,t=1;
int sum=0;
for(i=1;i<21;i++)
{
t*=i;
sum+=sum;
}
return 0;
}

4、根據輸入的百分製成績不同,輸出不同的五分製成績,用switch語句實現。
0-59: A 60-69: B N= 70-79: C 80-89: D 90-100:E
int main()
{ int score,grade,temp; cout<<"Input scroe:"<<endl; cin>>score; if(score>100||score<0) cout<<"error"<<endl; else { temp=score/10; switch(temp) { case 10: case 9: grade='A';break; case 8: grade='B';break; case 7: grade='C';break; case 6: grade='D';break; default: grade='E';break; } cout<<"grade:"<<grade<<endl; } return 0;}6、根據輸入的X的值,輸出Y的值,用if語句實現。
-1 (x<0)y= 0 (x=0) 1 (x>0)int main()
{
int x,y;
cout<<"please input x:"<<endl;
cin>>x;
if(x<0) y=-1;
else if(!x) y=0;
else y=1;
cout<<"y="<<y<<endl;
return 0;
}
7、設計一個程序,輸出所有的水仙花數。

#include <iostream>#include <cmath>using namespace std;
bool isNarcissus(int num){ int array[5]={0}; int tmp=num,i=0; while (tmp) { array[i++]=tmp%10; tmp/=10; }
if (pow(array[0],3)+pow(array[1],3)+pow(array[2],3)==num) return true; else return false;}
int main(){ int i=100; for (int j=0;i!=1000;++i) { if(isNarcissus(i)) { cout<<i<<" "; if (++j>5) { cout<<endl; j=0; } } } cout<<endl; return 0;}

❷ 求C語言編程題

邏輯運算和判斷選取控制

1、編製程序要求輸入整數a和b,若a2+b2大於100,則輸出a2+b2百位以上的數字,否則輸出兩數字之和。

#include<stdio.h>
int main()
{
int a,b;
printf("input two number:");
scanf("%d %d",&a,&b);
if((a*a+b*b)>=100)
printf("\n %d",(a*a+b*b)/100);
else
printf("\n %d",a+b);
getch();
}

2、試編程判斷輸入的正整數是否既是5又是7的整數倍數。若是,則輸出yes;否則輸出no。

#include<stdio.h>
int main()
{
int a;
printf("input a number:");
scanf("%d",&a);
if(a%5==0 && a%7==0)
printf("yes");
else
printf("no");
getch();
}

指針

1、編一程序,將字元串computer賦給一個字元數組,然後從第一個字母開始間隔的輸出該串,請用指針完成。

#include<stdio.h>
int main()
{
char string[]="computer";
char *p=string;
while(*p)
{
printf("%c",*p);
p++;
p++;
}
getch();
}

2、輸入一個字元串string,然後在string裡面每個字母間加一個空格,請用指針完成。

#include<stdio.h>
#include<CONIO.H>
#include<STDLIB.H>

#define max 100

char * String;

void (char *,char*);
void insert(char *);

int main()
{
char * string;
string = (char *)malloc(max*sizeof(char));
scanf("%s",string);
insert(string);
printf("%s",string);
getch();
return 0;
}

void (char * c,char * s)
{
while(*s!='\0')
{
*c=*s;
s++;
c++;
}
*c='\0';
}

void insert(char * s)
{
String = (char*)malloc(2*max*sizeof(char));
(String,s);
while(*String!='\0')
{
*s=*String;
s++;
String++;
*s=' ';
s++;
}
*s='\0';
}

一.選擇:
1.給出以下定義:
char acX[ ]= "abcdefg";
char acY[ ]= {'a','b','c','d','e','f','g'};
則正確的敘述為( )
A) 數組acX和數組acY等價 B) 數組acX和數組acY的長度相同
C) 數組acX的長度大於數組acY的長度 D) 數組acX的長度小於數組acY的長度
答案:C
2.
void example(char acHello[])
{
printf("%d", sizeof(acHello));
return;
}
void main()
{
char acHello[] = "hello";
example(acHello);//數組名稱作參數,傳的是地址,一個地址佔四個位元組
return;
}
的輸出是
A 4 B 5 C 6 D不確定
答案:A
3. 有以下程序段
char acArr[]= "ABCDE";
char *pcPtr;
for(pcPtr = acArr; pcPtr < acArr + 5; pcPtr++)
{
printf("%s\n", pcPtr);
}
return;
輸出結果是( )
A) ABCD B) A C) E D) ABCDE
B D BCDE
C C CDE
D B DE
E A E
答案:D
4.在中斷中,不能同步獲取信號量,但是可以釋放信號量。
A.正確 B.錯誤
答案:A
5.以下敘述中不正確的是( )
A) 在不同的函數中可以使用相同名字的變數
B) 函數中的形式參數是局部變數
C) 在一個函數內定義的變數只在本函數范圍內有效
D) 在一個函數內的復合語句中定義的變數在本函數范圍內有效(復合語句指函數中的成對括弧構成的代碼)
答案:D
6.設有如下定義:
unsigned long pulArray[] = {6, 7, 8, 9, 10};
unsigned long *pulPtr;
則下列程序段的輸出結果為( )
pulPtr = pulArray;
*(pulPtr + 2) += 2;
printf ("%d,%d\n", *pulPtr, *(pulPtr + 2));
A)8,10 B)6,8 C)7,9 D)6,10
答案:D
7. 定義結構體時有下面幾種說法,請指出正確的(多選):______
A、結構體中的每個部分,最好進行四位元組對齊;
B、結構體的總長度最好是四位元組對齊;
C、結構中成員的存放不用考慮位元組對齊情況;
答案:A、B
8.void example()
{
int i;
char acNew[20];

for(i = 0; i < 10; i++)
{
acNew[i] = '0';
}
printf("%d\n", strlen(acNew));
return;
}
的輸出為( )
A 0 B 10 C 11 D不確定
答案:D
9.switch(c)中的c的數據類型可以是char、long、float、unsigned、bool. ( )
A. 正確 B. 錯誤
答案:B
10. 網路上傳輸的位元組序默認是大位元組的,如果主機是小位元組序,在網路通信時則須進行位元組序轉換;如果主機是
大位元組序,為了程序的一致性及可移植性,最好也在程序中加上位元組序轉換的操作(空操作)。
A. 正確 B.錯誤
答案:A
11. struct stu
{
int num;
char name[10];
int age;
};
void fun(struct stu *p)
{
printf("%s\n", (*p).name);
return;
}
void main()
{
struct stu students[3]={ {9801,"Zhang",20},
{9802,"Wang",19},
{9803,"Zhao",18} };
fun(students + 2);
return;
}
輸出結果是( )
A) Zhang B)Zhao C) Wang D) 18
答案:B
12.以下程序運行後,輸出結果是( )
void main( )
{
char *szStr = "abcde";
szStr += 2;
printf("%lu \n",szStr);
return;
}
A cde B 字元c的ASCLL碼值
C "abcde"這個常串中字元c所在的地址 D 出錯
答案:C
13. 在X86下,有下列程序
#include <stdio.h>
void main()
{
union
{
int k;
char i[2];
}*s,a;
s = &a;
s->i[0] = 0x39;
s->i[1] = 0x38;
printf("%x\n", a.k);
}
輸出結果是( )
A) 3839 B) 3938 C) 380039 D) 不可預知
答案:D
14. 全局變數可以定義在被多個.C文件包含著的頭文件中。
A. 正確 B. 錯誤
答案:B
15.void example()
{
int i;
char acNew[20] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};

for(i = 0; i < 10; i++)
{
acNew[i] = '0';
}
printf("%d\n", strlen(acNew));
return;
}
的輸出為:
A 0 B 10 C 11 D不確定
答案:B
16.下列定義正確的有(多選):( )
A: char *pcPtr = "abcd";
B: char pc[4]= "abcd";
C: char pc[] = "abcd";
D: char pc[] = 'abcd';
E: char pc[] = {'a','b','c','d','\0'};
F: char pc[] = 'a' 'b' 'c' 'd';
答案:ACE
17.在函數內部定義的變數(靜態變數、寄存器變數等特殊變數除外)的內存是在棧內存中,所以在定義函數內部的變數的時候,一定要保證棧不能夠溢出。如果臨時變數
佔用空間較大,應該使用內存申請的方式,這樣該變數指向的內存就是在堆內存中了。
A. 正確 B. 錯誤
答案:A
18.局部變數可以和全局變數重名,編譯的時候不會出現錯誤,但一旦不小心,就可能導致使用錯誤變數,所以在定時局部變數的時候,不要和全局變數重名。
A. 正確 B. 錯誤
答案:A
19.設有以下宏定義:
#define N 3
#define Y(n) ((N+1)*n) /*這種定義在編程規范中是嚴格禁止的*/
則執行語句:z = 2 * (N + Y(5 + 1));後,z的值為( )
A) 出錯 B) 42 C) 48 D)54
答案:C
20. int *(*ptr)();
則以下敘述中正確的是( )
A) ptr是指向一維組數的指針變數
B) ptr是指向int型數據的指針變數
C) ptr是指向函數的指針,該函數返回一個int型數據
D) ptr是指向函數的指針,該函數的返回值是指向int型數據的指針
答案:D
21. 0x12345678 在採用BigEndian中內存的排列順序是______,在採用LittleEndian內存中的排列順序是_______.
(答案從左到右內存地址依次增加)
A.12 34 56 78 B.34 12 78 56
C.78 56 34 12 D.56 78 12 34
答案:A C
二、填空:
1. .struct tagAAA
{
unsigned char ucId:1;
unsigned char ucPara0:2;
unsigned char ucState:6;
unsigned char ucTail:4;
unsigned char ucAvail;
unsigned char ucTail2:4;
unsigned long ulData;
}AAA_S;
問:AAA_S在位元組對齊分別為1、4的情況下,佔用的空間大小是多少?
答案:9 12
2.typedef struct tagTest
{
UCHAR ucFlag;
ULONG ulLen;
}TEST_S;

TEST_S test[10];

四位元組對齊方式時: sizeof(TEST_S) = ______, sizeof(test)________.
答案:8 80
3
char acHello[] = "hello\0world";
char acNew[15] = {0};
strcpy(acNew,acHello);
strlen(acNew) = _____
sizeof(acHello) = ______
答案:5 12
4.#pragma pack(4)/*編譯選項,表示4位元組對齊*/
int main(int argc, char* argv[])
{
struct tagTest1
{
short a;
char d;
long b;
long c;
};
struct tagTest2
{
long b;
short c;
char d;
long a;
};
struct tagTest3
{
short c;
long b;
char d;
long a;
};
struct tagTest1 stT1;
struct tagTest2 stT2;
struct tagTest3 stT3;

printf("%d %d %d", sizeof(stT1), sizeof(stT2), sizeof(stT3));
return 0;
}
#pragma pack()(編譯選項結束)
請問輸出結果是:_________
答案:12 12 16
5. enum ENUM_A
{
X1,
Y1,
Z1 = 5,
A1,
B1
};
enum ENUM_A enumA = Y1;
enum ENUM_A enumB = B1;
請問 enumA = ____; enumB = ______;
答案:1 7
6.以下程序的輸出結果是________.
#include <stdio.h>
int fun(int x,int y)
{
static int m = 0;8
static int i = 2;3
i += m + 1;12
m = i + x + y;
return m;
}
void main()
{
int j = 4;
int m = 1;
int k;
k = fun(j, m);
printf("%d,", k);
k=fun(j, m);
printf("%d\n", k);
return;
}
答案:8 17
7.以下程序的輸出結果為________
#define CIR(r) r*r /*請注意這種定義的缺陷,不允許這么定義*/
void main()
{
int a = 1;
int b = 2;
int t;
t = CIR(a + b);
printf("%d\n", t);
return;
}
答案:5
8.在VRP中,實現了strncpy類似的函數,定義如下:
#define CHAR char
#define ULONG unsigned long
#define VOID void

#define MACRO_COPYWORLDLENGTH 4

CHAR *VOS_strncpy(CHAR *pcDest, const CHAR *szSrc, ULONG ulLength)
{
CHAR *pcPoint = pcDest;

if(( NULL == szSrc ) || ( NULL == pcDest ) ))
{
return NULL;
}

while(ulLength && (*pcPoint = *szSrc))/*這里採用了在判斷語句中賦值的方式(*pcPoint = *szSrc),建議盡量不使用*/
{
pcPoint++;
szSrc++;
ulLength--;
}
if(!ulLength)
{
*pcPoint = '\0';
}
return pcDest;
}

VOID main(VOID)
{
CHAR szStrBuf[ ] = "1234567890";
CHAR szStrBuf1[ ] = "1234567890";
CHAR *szHelloWorld = "Hello World!";
strncpy(szStrBuf, szHelloWorld, MACRO_COPYWORLDLENGTH);
VOS_strncpy(szStrBuf1, szHelloWorld, MACRO_COPYWORLDLENGTH);
printf("%s %s", szStrBuf, szStrBuf1);
}
程序的輸出結果為________
答案:Hell567890 Hell
9.
char acHello[] = "hello\0world";
char acNew[15] = {0};
memcpy(acNew,acHello,12);
strlen(acNew) = _____
sizeof(acHello) = _____
答案:5 12
10. typedef struct Head
{
UCHAR aucSrc[6];
ULONG ulType;
} HEAD_S;

在強制一位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
在強制二位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
在強制四位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
答案:10 10 12
11.union tagAAAA
{
struct
{
char ucFirst;
short usSecond;
char ucThird;
}half;
long lI;
}number;

struct tagBBBBB
{
char ucFirst;
short usSecond;
char ucThird;
short usForth;
}half;

struct tagCCCC
{
struct
{
char ucFirst;
short usSecond;
char ucThird;
}half;
long lI;
};

在位元組對齊為1下,sizeof(union tagAAAA)、sizeof(struct tagBBBBB)、sizeof(struct tagCCCC)是____ ____ _____
在位元組對齊為4下,sizeof(union tagAAAA)、sizeof(struct tagBBBBB)、sizeof(struct tagCCCC)是____ ____ _____
答案:4 6 8
8 8 12
12.struct tagABC
{
char cB;
short sC;
char cD;
long lA;
}*pAbc;

pAbc = 0x100000;
那麼pAbc+0x100 = 0x_________; (ULONG)pAbc + 0x100 = 0x_________;(ULONG *)pAbc + 0x100 = 0x_________;(char *)pAbc + 0x100 = 0x_______;
答案:100C00 100100 100400 100100
13.unsigned long FUNC_C ( unsigned long ulAction )
{
unsigned long ulResult = 0 ;

switch ( ulAction )
{
case ACTION_A:
{
ulResult += 1 ;
break ;
}
case ACTION_B:
{
ulResult += 1 ;
}
default:
{
ulResult += 1 ;
}
}

printf( "ulResult = %u", ulResult ) ;

return ulResult ;
}
當輸入為ACTION_B時,輸出結果為: ulResult = _________;
答案:2(因為此分支沒有break分支)
14.下面的代碼中,函數Test執行完畢後,列印的結果是 _____。
unsigned long g_ulGlobal = 0;
void GlobalInit(unsigned long ulArg)
{
ulArg = 0x01;

return;
}

void Test()
{
GlobalInit(g_ulGlobal);
printf("%lu", g_ulGlobal);
return;
}
答案:0
15.以下程序的輸出的結果是___________
int x = 3;
void incre();
void main()
{ int i;
for (i = 1; i < x; i++)
{
incre();
}
return;
}
void incre()
{
static int x = 1;
x *= (x + 1);
printf("%d ",x);
return;
}
答案:2 6
16.以下程序的輸出的結果是___________
#pragma pack(4)/*四位元組對齊*/
int main(int argc, char* argv[])
{
unsigned char puc[4];
struct tagPIM
{
unsigned char ucPim1;
unsigned char ucData0:1;
unsigned char ucData1:2;
unsigned char ucData2:3;
}*pstPimData;

pstPimData = (struct tagPIM *)puc;

memset(puc, 0, 4);
pstPimData->ucPim1 = 1;
pstPimData->ucData0 = 2;
pstPimData->ucData1 = 3;
pstPimData->ucData2 = 4;

printf("%02X %02X %02X %02X\n", puc[0], puc[1], puc[2], puc[3]);
return 0;
}
#pragma pack()/*恢復預設對齊方式*/
答案:01 26 00 00
17.
char *pcColor = "blue1" ;
char acColor[] = "blue1" ;
strlen(pcColor) = _____
strlen(acColor) = _____
sizeof(pcColor) = _____
sizeof(acColor) = _____
答案:5 5 4 6
18.
char str[] = "\\\0";
char *p = str;
int n = 1000;
請計算
sizeof (str ) = ____________
sizeof ( p ) = ______________
sizeof ( n ) = ______________
答案:3 4 4
19.UCHAR *pucCharArray[10][10];
typedef union unRec
{
ULONG ulIndex;
USHORT usLevel[6];
UCHAR ucPos;
}REC_S;
REC_S stMax,*pstMax;

四位元組對齊方式時: sizeof(pucCharArray) = __指針的數組,每個指針的地址都是4位元組____, sizeof(stMax)=_______, sizeof(pstMax)=__地址______,sizeof(*pstMax)=________.
答案:400 12 4 12
20.typedef union unHead
{
UCHAR aucSrc [6];
struct tagContent
{
UCHAR ucFlag[3];
ULONG ulNext;
}Content;
}HEAD_S;
32CPU,VC編譯環境下:
在強制一位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
在強制二位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
在強制四位元組對齊情況下,請指出sizeof(HEAD_S) = ________;
答案:7 8 8
21.
UCHAR *pszTest = "hello";
UCHAR aucTest[] = "hello";
請問 sizeof(pszTest) = _____ , sizeof(*pszTest) = ______, sizeof(aucTest) = ______.
答案:4 1 6
22. struct BBB
{
long lNum;
char *pcName;
short sDate;
char cHa[2];
short sBa[6];
}*p;
p = 0x100000;
p + 0x1 = 0x____
(unsigned long)p + 0x1 = 0x______
(unsigned long *)p + 0x1 = 0x______
(char *)p + 0x1 = 0x______
答案:100018 100001 100004 100001
23.在4位元組對齊的情況:
typedef struct tagRec
{
long lA1;
char cA2;
char cA3;
long lA4;
long lA5;
} REC_S;

void main(int argc, char *argv[])
{
REC_S stMax ;
printf("\r\n sizeof(stMax)= %d",sizeof(stMax));
return;
}
輸出結果為:
sizeof(stMax)=____
答案:16
24.void main ()
{
unsigned long ulA = 0x11000000;
printf("\r\n%x",*(unsigned char *)&ulA);
return;
}
輸出結果為:
答案:0
三、指出下列程序中導致不能出現預期結果的唯一錯誤(不考慮編程規范錯誤)
1.下面程序用於輸出用戶輸入的字元串。請指出其中的問題
#define OK 0
#define ERR 1
#define ERROR (-1)
#define BUFFER_SIZE 256
int GetMemory(char **ppszBuf, int num)
{
if( NULL == ppszBuf )
{
ASSERT(0);
return ERROR;
}
*ppszBuf = (char *)malloc(num);
if(NULL == *ppszBuf)
{
return ERROR;
}
return OK;
}

void Test(void)
{
char *pcStr = NULL;
if(OK == GetMemory(&pcStr, BUFFER_SIZE))
{
scanf("%s",pcStr);/*這里假定BUFFER_SIZE足夠大,不會導致越界*/
printf(pcStr);
free(pcStr);
}

return;
}
答案:要採用printf("%s", str)的形式列印,否則如果輸入為%s, %d等形式可能會導致不可知現象。
2.此函數實現把32位IP地址(主機序)以字元串的方式列印出來,請找出代碼中的錯誤:
char *IpAddr2Str(unsigned long ulIpAddr)
{
char szIpAddr[32];

(void)VOS_sprintf(szIpAddr, "%d.%d.%d.%d", ulIpAddr >> 24,
(ulIpAddr >> 16) & 0xff, (ulIpAddr >> 8) & 0xff, ulIpAddr & 0xff);

return szIpAddr;
}
答案:函數的局部變數是存放在堆棧中的,此函數返回了堆棧中的地址,函數退出後堆棧中的內容不可用。
3.如下程序用於輸出"Welcome Home"。請指出其中的錯誤:
void Test(void)
{
char pcArray[12];
strcpy(pcArray,"Welcome Home");
printf("%s!", pcArray);
return;
}
答案:數組越界。
4.如下程序用於把"blue"字元串返回,請指出其中的錯誤:
char *GetBLUE(void)
{
char* pcColor ;
char* pcNewColor;
pcColor = "blue";
pcNewColor = (char*)malloc(strlen(pColor));
if(NULL == pcNewColor)
{
return NULL;
}
strcpy(pcNewColor, pcColor);
return pcNewColor;
}
答案:申請內存空間不足,字元串結尾還有'\0'。
5.下面程序期望輸出str = hello world,請指出其中的錯誤:

char * GetStr(char *p)
{
p = "hello world";
return p;
}

void main()
{
char *str = NULL;

if(NULL != GetStr(str))
{
printf("\r\n str = %s",str);
}
return;
}
答案:無法返回字元串,參數使用錯誤。

❸ 求一份C語言程序設計的期末考試試題!!!謝謝了

一. 選擇題 (共15題, 每題2分,共30分)

1. 定義結構體的關鍵字是( )

A. union B. enum C.struct D.typedef

2. 設整型變數a為5,使b不為2的表達式是( )

A. b=a/2 B. b=6-(--a) C. b=a%2 D. b=a>3?2:1

3. 下面哪一項是不正確的字元串賦值或賦初值的方法( )

A. char *str; str= 「china」;

B. char str[7]= {『c』, 『h』, 『i』, 『n』, 『a』};

C. char str1[]= 「china」,str2[]=「123」;

D. char str1[10]; str1= 「china」;

4. 以下對二維數組a進行正確初始化的是( )

A. int a[2][3]={{1,2},{3,4},{5,6}}; B. int a[ ][3]={1,2,3,4,5,6};

C. int a[2][ ]={1,2,3,4,5,6}; D. int a[2][ ]={{1,2},{3,4}};

5. 選出下列標識符中不是合法的標識符的是( )

A. hot_do B. cat1 C. _pri D. 2ab

6. 以下說法中正確的是( )

A. C語言程序總是從第一個的函數開始執行

B. 在C語言程序中,要調用的函數必須在main()函數中定義

C. C語言程序總是從main()函數開始執行

D. C語言程序中的main()函數必須放在程序的開始部分

7. 若已定義:int a[9], *p=a;並在以後的語句中未改變p的值,不能表示a[1]地址的表達式為( )

A. p+1 B. a+1 C. a++ D. ++p

8. 若有說明: int i,j=7, *p=&i;, 則與i=j; 等價的語句是( )

A. i= *p; B. *p=*&j; C. i=&j; D. i=* *p;

9. 若變數c為char類型,能正確判斷出c為小寫字母的表達式是( )

A. 『a』<=c<= 『z』 B. (c>= 『a』) || (c<= 『z』)

C. (『a』<=c) and (『z』>=c) D. (c>= 『a』) && (c<= 『z』)

10. 以下程序的輸出結果是( )

main()

{ int a[]={1,2,3,4,5,6,7,8,9}, *p;

p=a;

*(p+3)+=2;

printf( 「%d,%d\n」,*p,*(p+3) ); }

A. 0, 5 B. 1, 6 C. 1, 5 D. 0, 6

11. 以下程序的輸出結果是( )

main()

{ int a=5;

float x=3.14;

a*=x*(『E』- 『A』);

printf(「%f\n」,(float)a); }

A. 62.000000 B. 62.800000 C. 63.000000 D. 62

12. 以下程序的輸出結果是( )

#define f(x) x*x

main()

{ int a=6,b=2,c;

c=f(a)/f(b);

printf(「%d\n」,c); }

A. 9 B. 6 C. 36 D. 18

13. 定義如下變數和數組:int i; int x[3][3]={1,2,3,4,5,6,7,8,9};

則語句for(i=0;i<3;i++) printf("%d ",x[i][2-i]); 的輸出結果是( )

A. 1 5 9 B. 1 4 7 C. 3 5 7 D. 3 6 9

14. 下列程序段的輸出結果是 ( )

void main( )

{ int k;

for (k=1;k<5;k++)

{ if(k%2!=0)

printf( 「#」 );

else

printf(「*」) ; }

}

A. #*#* B . *#*# C. ## D. **

15. 下列程序執行後輸出的結果是( )

int d=1;

fun (int p)

{ int d=5;

d + =p + +;

printf("%d,",d); }

main( )

{ int a=3;

fun(a);

d + = a + +;

printf("%d\n",d); }

A. 8, 4 B. 9, 6 C. 9, 4 D. 8, 5

二. 填空題(共7題,每空2分,共30分)

1. 數組 int a[3][5]; 共定義了_______________個元素。

2. 有float f=3.1415927; 則 printf(「%5.4f」, f );輸出的結果是_______________。

3. 下面程序的功能是:輸出 100以內(不包含100)能被 3整除且個位數為 6的所有整數,請填空。

main( )

{ int i;

for(i=1; _______________; i++)

if (_______________)

printf("%d", i);

}

4. 設有「int x=2, y」說明,則逗號表達式「y=x+5,x+y」的值是 _______________

5. 以下是使用指針,進行字元串復制的程序,請填空。

main()

{ char a[]= 「Tsinghua University」, b[30], *p1,*p2;

p1=a;

p2=b;

for(; *p1!= 『_______________』; p1++, p2++)

_______________=_______________;

*p2= 『_______________』;

printf(「string a is:%s\n」,a);

printf(「string b is:%s\n」,b);

}

6. 下面程序用冒泡法對數組a進行降序排序,請填空。

main()

{ int a[5]={4,7,2,5,1};

int i,j,m;

for(i=0;i<4;i++)

for(j=0;j<_______________;j++)

if( _______________< _______________ )

{ m=a[ j];

a[ j]=a[ j+1];

a[ j+1]= m; }

for(i=0;i<5;i++)

printf("%d ",a[i]);

}

7. 函數fun的功能是:使一個字元串按逆序存放,請填空。

void fun (char str[])

{ char m; int i,j;

for(i=0,j=strlen(str);i<_______________;i++,j--)

{ m=str[i];

str[i]= _______________;

str[j-1]=m;

}

printf("the rotated string is %s\n",_______________);

}

❹ c語言編程題

C語言編程題
1.(*)求分數序列:1/2,2/3,3/5,5/8,8/13,13/21...... 前20項的和。
main()
{float i=1,j=2,t=0,s,n,m;
for(n=1;n<=20;n++)
s=i/j,m=i,i=j,j=m+j,t=t+s;
printf("t=%f",t);
}
2.(*)從鍵盤輸入一個字元串,再將其逆序輸出。(如:輸入abcde,輸出edcba)
main()
{int i;
char c[10];
scanf("%s",c);
for(i=9;i>=0;i--)
printf("%c",c[i]);
}
3.(*)已知abc+cba=1333,其中a、b、c均為一位數,例如:617+716=1333, 518+815=1333,
試編程求出符合這一規律的a、b、c,並輸出結果。
main()
{int a,b,c,x,y;
for(a=1;a<=9;a++)
for(b=0;b<=9;b++)
for(c=1;c<=9;c++)
{ x=100*a+10*b+c;
y=100*c+10*b+a;
if(x+y==1333)
printf("x=%d,y=%d",x,y);}
}
4.(*)利用海倫公式求三角形面積,三邊長a,b,c由鍵盤輸入。若輸入的三邊長不能構成
三角形,輸出相應提示信息。海倫公式如下:其中s=(a+b+c)/2
三角形面積=
#include"math.h"
main()
{ float a,b,c,s,area;
scanf("%f,%f,%f",&a,&b,&c);
s=(a+b+c)/2;
area=sqrt(s*(s-a)*(s-b)*(s-c));
if(a+b>c&&a+c>b&&b+c>a)
printf("area=%f",area);
else
.1 .
printf("no");
}_
5.(*)編程求出1!+2!+3!+…+8!+9!+10!的值並輸出。
程序1: main()
{ int i,j;
double p=1, sum=0;
for(i=1;i<=10;i++)
{ for(j=1;j<=i;j++)
p=p*i;
sum=sum+p;p=1.0;}
printf("sum=%f",sum);
}_
程序2:float fac(n)
int n;
{flo

❺ c語言編程題

2011年小學期C語言程序設計訓練實習報告程序源代碼
(實驗一)
1-1:
/*輸入一串字元,以「?」結束,統計各字母出現的次數,並按字母出現的多少輸出(先輸出字母出現多的,次數相同的按照字母表順序輸出,不出現的不輸出)*/
#include <stdio.h>
#include<string.h>
#include<stdlib.h>
#define N 100
void main()
{void f(int a[],char str[]);
char str[N];
int a[26]={0};
int i,j;
printf("請輸入一行字元,以?結尾:\n");
gets(str);
if(strlen(str)=='?')
{
f(a,str);
}else
{
printf("請重新輸入,以?結尾!\n");
for(j=0;j<N;j++)
str[j]='\0';
gets(str);
f(a,str);
}
for(j=100;j>0;j--)
for(i=0;i<26;i++)
if(a[i]==j) printf("%c字母有%d個。\n",i+97,a[i]);
}
void f(int a[],char str[])
{int i;
for(i=0;str[i]!='?';i++)
{
if(str[i]>='a'&&str[i]<='z') a[str[i]-97]++;
else if(str[i]>='A'&&str[i]<='Z') a[str[i]-65]++;
}

}
1-2:
/*插入排序(在輸入的過程中完成排序)。以任意次序讀入20個數,將第1個數放入數組a的第一個元素中。以後讀入的數應與已經存入數組a中的數進行比較,確定它在從小到大排列中所應處的位置。將該位置及其以後的元素向後推移一個數的位置,將新讀入的數填入空出的位置中。這樣在數組a中的數總是從小到大排列的,處理完後輸出。*/
#include <stdio.h>
void main()
{
int a[20];
int i,j,k,t;
for(j=0;j<20;j++)
{
printf("請輸入第%d個數:",j+1);
scanf("%d",&a[j]);
for(i=0;i<j;i++)
{
if(a[j]<a[i])
{
t=a[j];
for(k=j;k>i;k--) a[k]=a[k-1];
a[i]=t;
break;
}
}
}
for(i=0;i<20;i++)
printf("排序為:%d\t",a[i]);
}
1-3:
/*從鍵盤上接收一個最多至9位整數、2位小數的數值,請將其轉換成大寫金額,即寫成:×億×仟×佰×拾×萬×仟×佰×拾×元×角×分的形式。例如:當從鍵盤上輸入 374910.56 時,輸出結果為:×億×仟×佰叄拾柒萬肆仟玖佰壹拾零元伍角陸分或叄拾柒萬肆仟玖佰壹拾零元伍角陸分*/
#include<stdio.h>
#include<string.h>
#include<math.h>
void main()
{
void f(int i);
char a[13]={'0'};int N,i,M,n=0;double money=0;int j,b,t;long c[11];char *d[]={"零","壹","貳","叄","肆","伍","陸","柒","捌","玖"};
printf("請輸入金額(最多至9位整數2位小數):\n");
gets(a);N=strlen(a);
printf("大寫金額為:\n");
if(N==12)
{for(i=0;i<N;i++)
{if(a[i]='.')
{a[i]=a[i+1];a[i+1]=a[i+2];}}}
else
{ for(i=0;i<N;i++)
{if(a[i]!='.')
{money=money+(a[i]-48)*pow(10,N-i-2);}
else
{ M=i;break;} }
for(i=M+1;i<N;i++)
money=money+(int)(a[i]-48)*pow(10,N-i-1);
if(N-M==2)
money=money*10; b=(long int)(money);
c[0]=b/10000000000;t=b-10000000000*c[0];
c[1]=t/1000000000;t=t-1000000000*c[1];
c[2]=t/100000000;t=t-100000000*c[2];
c[3]=t/10000000;t=t-10000000*c[3];
c[4]=t/1000000;t=t-1000000*c[4];
c[5]=t/100000;t=t-100000*c[5];
c[6]=t/10000;t=t-10000*c[6];
c[7]=t/1000;t=t-1000*c[7];
c[8]=t/100;t=t-100*c[8];
c[9]=t/10;t=t-10*c[9];
c[10]=t;
for(i=0;i<11;i++)
a[i]=c[i]+48;
}
for(i=0;i<11;i++)
{
for(j=0;j<10;j++)
{
if(a[i]==j+48)
{ if(a[i]!='0')
{ printf("%s",d[j]);f(i);n=1;}
if(a[i]=='0'&&n==1){printf("%s",d[0]);f(i);} }
}
}
}
void f(int i)
{char *a[]={"億","仟","佰","拾","萬","仟","佰","拾","元","角","分"};int j;
for(j=0;j<11;j++)
if(i==j)printf("%s",a[j]);
}
1-4:
/*編程實現將字元串中最短的單詞輸出,在主函數中輸入字元串,編寫一個函數完成最短單詞查找,例如:輸入:Happy new year 最短單詞為new,輸出new*/
#include <stdio.h>
#include <string.h>
int f1(char c)
{
if((c>='a'&&c<='z')||(c>='A'&&c<='Z'))
return(1);
else return(0);
}
int f(char a[])
{
int i,l,len=0,length=100,flag=1,place=0,point;
l=strlen(a);
for(i=0;i<=l;i++)
if(f1(a[i]))
if(flag) {point=i;flag=0;}
else len++;
else
{
flag=1;
if(len<=length)
{
length=len;place=point;
}
len=0;
}
return (place);
}
void main()
{
int i;
char str[100];
printf("輸入一行字元:");
gets(str);
printf("最短單詞是:");
for(i=f(str);f1(str[i]);i++)
printf("%c",str[i]);
printf("\n");
}
1-5:
/*用隨機函數產生數據,設計二位整數的加、減、乘算式各一題(減法算式應保證被減數大於減數)。讓學生回答,由計算機給出正確與否的判斷,並最後給出總得分。得分計算方法:算對加、減法各得30分,算對乘法得40分,算錯得0分。然後由計算機輸出詢問信息,學生選擇回答,以決定是否繼續一次新的測驗。*/
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void main()
{
void f(void);
f();
}
void f()
{
srand((unsigned)time(NULL));
int b,a,i=0,d;char c;
a=rand()%(100-9+1)+9;
b=rand()%(100-9+1)+9;
printf("請回答問題一:\n");
printf("%d+%d=\n",a,b);
scanf("%d",&d);
if(d==a+b)
{i=i+30;printf("回答正確!\n");}
else
printf("回答錯誤!\n");

do{
a=rand()%(100-9+1)+9;
b=rand()%(100-9+1)+9;}while(a<b);
printf("請回答問題二:\n");
printf("%d-%d=\n",a,b);
scanf("%d",&d);
if(d==a-b)
{i=i+30;printf("回答正確!\n");}
else
printf("回答錯誤!\n");
a=rand()%(100-9+1)+9;
b=rand()%(100-9+1)+9;
printf("請回答問題二:\n");
printf("%d*%d=\n",a,b);
scanf("%d",&d);
if(d==a*b)
{i=i+40;printf("回答正確!\n");}
else
printf("回答錯誤!\n");
printf("您的總得分為:%d\n",i);
printf("您希望再做一輪新的測試嗎?\n請輸入 'Y' 或 'N'\n");
scanf("%*c%c",&c);
for(;;)
{
if(c!='y'&&c!='Y'&&c!='n'&&c!='N')
{printf("輸入錯誤!重新輸入:\n");
scanf("%*c%c",&c);}
else
break;}
if(c=='y'||c=='Y')
f();

}

❻ c語言編程例題

#include<iostream>
#include<math.h>

usingnamespacestd;

//判斷一個數是否為素數
boolIsPrimeNumber(intiNum)
{
boolbRtn=true;
if(iNum<=1)
{
returnfalse;
}
intiTmp=sqrt((double)iNum);
for(inti=2;i<=iTmp;++i)
{
if((iNum%i)==0)
{
bRtn=false;
break;
}
}
returnbRtn;
}

//判斷一個數是否為偶數
//true,偶數;false,奇數
boolIsEvenNumber(intiNum)
{
return((iNum%2)==0)?true:false;
}

//查找小於1000的迴文素數
voidFindPalindromePrimes(intiNum)
{
boolbRst=false;
inti=2;
intiHundDigit=0,iTenDigit=0,iSingleDigit=0;
for(i;i<1000;++i)
{
if(IsPrimeNumber(i))
{
if(i<10)
{
bRst=true;
cout<<i<<"";//輸出迴文素數.
}
elseif((i>=10)&&(i<100))
{
iTenDigit=i/10;
iSingleDigit=i%10;
//如果個位上的數與10位上的數相等
if(iTenDigit==iSingleDigit)
{
bRst=true;
cout<<i<<"";
}
}
else
{
intiTmp=i;
iHundDigit=iTmp/100;
iTmp=iTmp%100;
iTenDigit=iTmp/10;
iSingleDigit=iTmp%10;
if((iHundDigit==iTenDigit)&&(iTenDigit==iSingleDigit))
{
bRst=true;
cout<<i<<"";
}
}
}
}
if(!bRst)
{
cout<<"沒有小於1000的迴文素數!"<<endl;
}
}

//查找小於100的絕對素數
voidFindAbsolutePrime(intiNum)
{
boolbRst=false;
inti=2,iTmp=0;
intiTenDigit=0,iSingleDigit=0;
for(i;i<100;++i)
{
if(IsPrimeNumber(i))
{
iTenDigit=i/10;
iSingleDigit=i%10;
iTmp=iSingleDigit*10+iTenDigit;
if(IsPrimeNumber(iTmp))
{
bRst=true;
cout<<i<<"";
}
}
}
if(!bRst)
{
cout<<"沒有小於100的絕對素數!"<<endl;
}
}

//分解10~20之間的偶數
voidResolveEventNum(intiNum)
{
boolbRst=false;
inti=2,iTmp=0;
for(;i<iNum;++i)
{
if(IsPrimeNumber(i))
{
iTmp=iNum-i;
if(IsPrimeNumber(iTmp))
{
bRst=true;
cout<<iNum<<"分解為"<<i<<"+"<<iTmp<<endl;
break;
}
}
else
continue;
}
if(!bRst)
{
cout<<"不能分解為兩個素數之和!"<<endl;
}
}

intmain(void)
{
intiInput=0;
cout<<"請輸入一個大於1的整數:";
cin>>iInput;
if(IsEvenNumber(iInput))
{
cout<<iInput<<"是一個偶數"<<endl;
if((iInput>=10)&&(iInput<=20))
{
ResolveEventNum(iInput);
}
}
else
{
cout<<iInput<<"是一個奇數"<<endl;
cout<<"查找小於1000的迴文數:"<<endl;
FindPalindromePrimes(iInput);
cout<<endl;
cout<<"查找小於100的絕對素數:"<<endl;
FindAbsolutePrime(iInput);
cout<<endl;
}
getchar();
return0;
}

附上運行結果(如果滿意,麻煩設為最佳答案,做任務需要,謝謝!):

❼ C語言期末綜合編程

#include <stdio.h>
#include <stdlib.h>
/* 1。根據學生信息定義一個結構體類型,再說明一個該結構體類型的數組。*/
struct stu_info{
char stuNo[10];/* No */
char stuName[30];/* Name */
float stuScore[3];/* the three scores */
float aveScore; /* average score */
float totalScore; /* total score */
}stu[10];
/* 2。用input函數從鍵盤上輸入10個學生的數據。 */
void input()
{ int i = 0;
printf("Input the students' infomation(FORMAT LIKE:No Name score1 score2 score3):\n");
while(i < 10)
{ printf("Input %d:",i + 1);
scanf("%s%s%f%f%f",stu[i].stuNo,stu[i].stuName,&stu[i].stuScore[0],&stu[i].stuScore[1],&stu[i].stuScore[2]);
i++;
}
}
/* 3。用average函數求出每個學生總成績、平均成績和所有學生的總平均成績。 */
float average()
{ int i = 0;
float totalAve_score = 0;
while(i < 10)
{ stu[i].totalScore = stu[i].stuScore[0]+stu[i].stuScore[1]+stu[i].stuScore[2];
stu[i].aveScore = stu[i].totalScore/3;
totalAve_score += stu[i].aveScore;
i++; }
totalAve_score /= 10;
return totalAve_score; }
/* 4。用maximum函數找出最高分的學生的數據。 */
int maximun()
{ int i = 0, k=0;
float tmp=stu[0].totalScore;
while(++i < 10)
{ if(tmp < stu[i].totalScore)
{ tmp = stu[i].totalScore;
k = i;
}
}
return k;
}
/* 5。在主函數中輸出每位學生的學號、姓名、三門課成績、總成績和平均成績以及總平均分和最高分學生的數據。*/
int main(int argc, char *argv[])
{ int i = 0, highestNo;
float totalAve_score;
input(); totalAve_score = average();
highestNo = maximun();
printf("NO.\t Name\tScore1\tScore2\tScore3\tTotal\taverage\n");
for(i = 0;i < 10;i++)
printf("%s %s\t %.1f\t%.1f\t%.1f\t%.2f\t%.2f\n",stu[i].stuNo,stu[i].stuName,stu[i].stuScore[0],stu[i].stuScore[1],stu[i].stuScore[2],stu[i].totalScore,stu[i].aveScore);
printf("average = %.2f\n",totalAve_score);
printf("The highest score:%s,score total:%.2f",stu[highestNo].stuName,stu[highestNo].totalScore);
system("PAUSE");
return 0;
}

❽ C語言期末考試編程題

1輸入兩個整數a和b,若a和b的平方和大於100,則輸出平方和的百位以上的數字,否則輸出a和 b的和。
要求: 1)輸出結果時說明平方和是大於100還是小於100( >100或<100 )
#include<stdio.h>
int main(){
int a, b, c;
scanf("%d%d", &a, &b);
c = a * a + b * b;
if(c > 100) printf("平方和大於100\n%d\n", c%100);
else printf("平方和小於等於100\n%d\n", a + b);
return 0;
}
2輸入一個整數,判斷是否是5和7的公倍數,若是則輸出:5and7yes,否則再判斷是否是3的倍數,若是3的倍數輸出:3yes,若都不是則輸出:no
#include<stdio.h>
int main(){
int input;
scanf("%d", &input);
if(input % 5 == 0 && input % 7 == 0)printf("5and7yes\n");
else if(input % 3 == 0) printf("3yes\n");
else printf("no\n");
return 0;
}
第三,四題和第二題差不多
5計算公式: [ 2*x x=2
y= [ x*x+1 x<2
[ 2*x*x+3*x+1 x>2
要求: 1)從鍵盤輸入x的值,根據x的值求y的值
2)輸出y的值
#include<stdio.h>
int main(){
int x, y;
scanf("%d", &x);
if(x == 2) y = 2*x;
else if(x < 2) y = x*x+1;
else y = 2 * x * x + 3 * x + 1;
printf("%d\n", y);
return 0;
}
8 和7差不多
下面原理都差不多 用if基本都能搞定 判斷條件就行了 應該LZ能搞定了 東西有點多 -。- 就寫這些吧 其他的就不一一寫了^ ^

❾ C語言期末考試編程大題求教

#include <stdio.h>

#include <malloc.h>

#include <string.h>


typedef struct info

{

int no;

char name[20];

char s;

float score;

struct info *next;

}NODE;


NODE *creat()

{

NODE *head = NULL;

NODE *p,*r =NULL;

char str[100] = {0};

NODE tmp = {0};

gets(str);

sscanf(str,"%d %s %c %f", &(tmp.no), tmp.name, &(tmp.s), &(tmp.score));

while(strlen(str)>5)

{

p = (NODE*)malloc(sizeof(NODE));

memcpy(p,&tmp,sizeof(NODE));

if (NULL==head)

{

head = p;

}else

{

r->next = p;

}

r = p;

gets(str);

sscanf(str,"%d %s %c %f", &(tmp.no), tmp.name, &(tmp.s), &(tmp.score));

}

r->next = NULL;

return head;

}


NODE *findmax(NODE *p)

{

NODE tmp = {0};

NODE *ptr = NULL;

while (p)

{

if (p->score > tmp.score)

{

memcpy(&tmp,p,sizeof(NODE));

ptr = p;

}

p = p->next;

}

return ptr;

}


void prn(NODE *p)

{

printf("no<%d> name<%s> sex<%c> score<%f>", p->no,p->name,p->s,p->score);

}


void freelst(NODE *pHead)

{

NODE *p;


while (pHead)

{

p = pHead;

pHead = pHead->next;

free(p);

p = NULL;

}

}


void main()

{

NODE *head,*p;

head=creat(); //創建list

p=findmax(head); //查找max

prn(p); //輸出信息

freelst(head); //釋放申請到的內存空間

}