Ⅰ c語言:輸入兩個分數,計算它們的和。用a/b+c/d=x/y的形式。源程序
1.一個C程序的執行是從( A )。
A) 本程序的main函數開始,到main函數結束
B) 本程序文件的第一個函數開始,到本程序文件的最後一個函數結束
C) 本程序的main函數開始,到本程序文件的最後一個函數結束
D) 本程序文件的第一個函亮臘數開始,到本程序的main函數結束
2.以下敘述正確的是( C )。
A) 在C程序中,main函數必須位於程序的最前面
B) C程序的每行中只能寫一條語句
C) C語言本身沒有輸入輸出語句
D) 在對一個C程序進行編譯的過程中,可發現注釋中的拼寫錯誤
3.以下敘述不正確的是( D )。
A) 一個C源程序可由一個或多個函數組成
B) 一個C源程序必須包含一個main函數
C) C程序的基本組成單位是函數
D) 在C程序中,注釋說明只能位於一條語句的後面
4.C語言規定,在一個源程序中,main函數的位置( C )。
A) 必須在最開始 B) 必須在系統調用的庫函數的後面
C) 可以任意 D) 必須在最後
5.一個C語言源程序是由( B )。
A) 一個主程序和若乾子程序組成 B) 函數組成
C) 若干過程組成 D) 若乾子程序組成
二 填空題
1.C源程序的基本單位是 函數 。
2.一個C源程序中至少應包括一個 main函數 。
3.在一個C源程序中,注釋部分兩側的分界符分別為 /* 和 */ 。
4.一個函數是由兩部分組成的,它們分別是 函數名 和 函數體 。
5.在C語言中,一個函數的函數體一般包括 聲明部分 和 執行部分 。
第三章 數據類型、運算符與表達式
一 單項選擇題
1.下面四個選項中,均不是c語言關鍵字的選項是( A )。
A) define IF Type B) getc char printf
C) include scanf case D) while go pow
2.C語言中的標識符只能由字母、數字和下劃線三種字元乎昌組成,且第一個字元( C )。
A) 必須為字母 B) 必須為下劃線
C) 必須為字母或下劃線 D) 可以是字母、數字和下劃線中任一種字元
3.下列四個選項中,均是C語言關鍵字的選項是( B )。
A) auto enum include B) switch typedef continue
C) signed union scanf D) if struct type
4.下面四個選項中,均是不合法的用戶標識符的選項是( C )。
A) A P_0 do B) float la0 _A
C) b-a goto int D) _123 temp int
5.以下有4組用戶標識符,其中合法的一組是( C )。
A) For -sub Case B) 4d DO Size
C) f2_G3 IF abc D) WORD void define
二 填空題
1.若x和a均是int型變數,則計算表達式(1)後的x值為 12 ,計算表達式(2)後的x值為 4 。
(1) x=(a=4, 6*2)
(2) x=a=4, 6*2
2.若a是int型變數歲鍵扒,則表達式(a=4*5, a*2), a+6的值為 26 。
3.若b是int型變數,則表達式b=25/3%3的值為 2 。
4.若s是int型變數,且s=6 則下面表達式s%2+(s+1)%2的值為 1 。
5.若a,b和c均是int型變數,則計算表達式a=(b=4)+(c=2)後,a值為 6 ,b值為 4 ,c值為 2 。
6.若x和n均是int型變數,且x和n的初值均為5,則計算表達式x+=n++後x的值為 10 ,n的值為 6 。
7.若有定義:int b=7;float a=2.5,c=4.7;則表達式a+(int)(b/3*(int)(a+c)/2)%4的值為 4.5 。
8.若有定義:int a=2,b=3;float x=3.5,y=2.5;則表達式(float)(a+b)/2+(int)x%(int)y的值為 3.5 。
9.若有定義:int x=3,y=2;float a=2.5,b=3.5;則表達式(x+y)%2+(int)a/(int)b的值為 1 。
10.若x和n均是整型變數,且x的初值為12,n的初值為5,則計算表達式x%=(n%=2)後x的值為 0 。
第四章 最簡單的C程序設計——順序程序設計
一 單項選擇題 1~5 BDDAB
1.printf函數中用到格式符%5s,其中數字5表示輸出的字元串佔用5列,如果字元串長度大於5,則輸出按方式( B )。
A) 從左起輸出該字元串,右補空格
B) 按原字元長從左向右全部輸出
C) 右對齊輸出該字串,左補空格
D) 輸出錯誤信息
2.已有定義int a= -2; 和輸出語句 printf(「%8x」,a); 以下正確的敘述是( D )。
A) 整型變數的輸出形式只有%d一種
B) %x是格式符的一種,它可以適用於任何一種類型的數據
C) %x是格式符的一種,其變數的值按十六進制輸出,但%8x是錯誤的
D) %8x不是錯誤的格式符,其中數字8規定了輸出欄位的寬度
3.若x, y均定義成int型,z定義為double型,以下不合法的scanf函數調用語句是
( D )。
A) scanf(「%d %x, %le」, &x, &y, &z);
B) scanf(「%2d *%d, %lf」, &x, &y, &z);
C) scanf(「%x %*d %o」, &x, &y);
D) scanf(「%x %o%6.2f」, &x, &y, &z);
4.以下程序的輸出結果是( D )。
main( )
{ int k=17;
printf("%d,%o,%x\n",k,k,k);
}
A)17,021,0x11 B)17,17,17
B)17,0x11,021 D)17,21,11
5.下列程序的運行結果是( B )。
#include <stdio.h>
main()
{ int a=2,c=5;
printf("a=%d,b=%d\n",a,c);
}
A) a=%2,b=%5 B) a=2,b=5
C) a=d,b=d D) a=2,c=5
二 填空題
1.下面程序的運行結果是 i:dec=4,oct=4,hex=4,unsigned=65531 。
main()
{
short i;
i= -4;
printf(「\ni: dec=%d, oct=%o, hex=%x, unsigned=%u\n」, i, i, i, i);
}
2.若想通過以下輸入語句使a=5.0,b=4,c=3,則輸入數據的形式應該是 5.0,4,c=3 。
int b,c; float a;
scanf("%f,%d,c=%d",&a,&b,&c);
3.下列程序的輸出結果是16.00,請填空。
main()
{ int a=9, b=2;
float x= 6.6 , y=1.1,z;
z=a/2+b*x/y+1/2;
printf("%5.2f\n", z );
}
4.在printf格式字元中,只能輸出一個字元的格式字元是 c ;用於輸出字元串的格式字元是 s ;以小數形式輸出實數的格式字元是 f ;以標准指數形式輸出實數的格式字元是 e 。
三 編程題
1. 若a=3, b=4, c=5, x=1.2, y=2.4, z= -3.6, u=51274, n=128765, c1=』a』, c2=』b』。想得到以下的輸出格式和結果,請寫出完整的程序(包括定義變數類型和設計輸出)。
要求輸出的結果如下:
a= <空格>3 <空格><空格> b= <空格> 4<空格><空格> c= <空格>5
x=1.200000, y=2.400000, z= -3.600000
x+y=<空格>3.60<空格><空格> y+z = -1.20<空格><空格>z+x= -2.40
u=<空格>51274<空格><空格>n=<空格><空格><空格>128756
c1= a <空格>or<空格>97(ASCII)
c2= B <空格>or<空格>98(ASCII)
/*
void main()
{
int a, b, c;
unsigned u;
long int n;
float x, y, z;
char c1,c2;
a=3, b=4, c=5, x=1.2, y=2.4, z= -3.6, u=51274, n=128765, c1='a', c2='b';
printf("a=%2d b=%2d c=%2d\n", a, b, c);
printf("x=%f, y=%f, z=%+f\n");
printf("x+y=%5.2f y+z =%+5.2f z+x=%+5.2f\n", x+y, y+z, z+x);
printf("u=%6d n=%9d\n");
printf("c1=%c or %d(ASCII)\n", c1, c1);
printf("c2=%c or %d(ASCII)\n", c2-32, c2);
}
*/
2. 輸入一個華氏溫度,要求輸出攝氏溫度。公式為
輸出要有文字說明,取2位小數。
/*
void main()
{
float c, f;
printf("輸入一個華氏溫度:\n");
scanf("%f", &f);
c = 5.0/9.0*(f-32);
printf("\n輸入的華氏溫度 %.2f,攝氏溫度為: %.2f\n", f, c);
}
*/
3. 編程序,用getchar函數讀入兩個字元給c1、c2,然後分別用putchar函數和printf函數輸出這兩個字元。
/*
void main()
{
char c1, c2;
c1 = getchar();
c2 = getchar();
putchar(c1);
putchar(c2);
printf("\nc1 = %c; c2 = %c\n", c1, c2);
}
*/
第五章 選擇結構程序設計
一 單項選擇題
1.邏輯運算符兩側運算對象的數據類型是( D )。
A) 只能是0或1
B) 只能是0或非0正數
C) 只能是整型或字元型數據
D) 可以是任何類型的數據
2.已知x=43, ch='A', y=0;則表達式(x>=y&&ch<'B'&&!y)的值是( C )。
A) 0 B) 語法錯 C) 1 D) 「假」
3.已知 int x=10, y=20, z=30; 以下語句執行後x, y, z的值是( B )。
if(x>y)
z=x;x=y;y=z;
A) x=10,y=20,z=30 B) x=20,y=30,z=30
C) x=20,y=30,z=10 D) x=20,y=30,z=20
4.執行下列語句後a的值為( 2 ),b的值為( 1 )。( C )
int a, b, c;
a=b=c=1;
++a|| ++b && ++c;
A) 錯誤 1 B) 2 2 C) 2 1 D) 1 1
5.若希望當A的值為奇數時,表達式的值為「真」,A的值為偶數時,表達式的值為「假」,則以下不能滿足要求的表達式是( C )。
A) A%2==1 B) !(A%2==0) C) !(A%2) D) A%2
二 填空題
1.若從鍵盤輸入58,則以下程序輸出的結果是 585858 。
main()
{ int a;
scanf(「%d」,&a);
if(a>50) printf(「%d」,a);
if(a>40) printf(「%d」,a);
if(a>30) printf(「%d」,a);
}
2.下面程序的運行結果是 -1 。
main()
{
int a=2, b=3, c;
c=a;
if(a>b) c=1;
else if(a==b) c=0;
else c=-1;
printf(「%d\n」,c);
}
3.以下程序實現:輸入三個整數,按從大到小的順序進行輸出。請填空。
main()
{
int x, y, z, c;
scanf(「%d %d %d」, &x, &y, &z);
if( x<y )
if( x<z )
if( y<z )
printf(「 %d %d %d」, x, y, z);
}
4.如果運行時輸入字元Q,則下面程序的運行結果是 Q 。
main()
{
char ch;
scanf(「%c」, &ch);
ch=(ch>=『A』&& ch<=『Z』)? (ch+32):ch;
ch=(ch>=『a』&& ch<=『z』)? (ch-32):ch;
printf(「%c」, ch);
}
5.若x為int類型,請以最簡單的形式寫出與邏輯表達式!x等價的C語言關系表達式 x==0 。
第六章 循環控制
一 單項選擇題
1.下面程序段的運行結果是( C )。
int n=0;
while(n++<=2);
printf(「%d」,n);
A) 2 B) 3 C) 4 D) 有語法錯
2.設有程序段:
t=0;
while(printf(「*」))
{t++;
if(t<3) break;
}
下面描述正確的是( D )。
A) 其中循環控製表達式與0等價
B) 其中循環控製表達式與'0'等價
C) 其中循環控製表達式是不合法的
D) 以上說法都不對
3.下面程序的功能是將從鍵盤輸入的一對數,由小到大排序輸出,當輸入一對相等數時結束循環,請選擇填空( B )。
#include <stdio.h>
main()
{int a,b,t;
scanf(「%d%d」,&a,&b);
while( ___________ )
{if(a>b)
printf(「%d,%d\n」,a,b);
scanf("%d%d",&a,&b);
}
}
A) !a=b B) a!=b C) a==b D) a=b
4.C語言中,while和do-while循環的主要區別是( A )。
A) do-while的循環體至少無條件執行一次
B) while的循環控制條件比do-while的循環控制條件更嚴格
C) do-while允許從外部轉到循環體內
D) do-while的循環體不能是復合語句
5.對以下程序段描述正確的是( C )。
x=-1;
do
while(!x);
A) 是死循環 B) 循環執行二次
C) 循環執行一次 D) 有語法錯誤
二 填空題
1.以下程序運行後的輸出結果是 52 。
main()
{ int i=10, j=0;
do
while(i>2);
printf("%d\n",j);
}
2.設有以下程序:
main()
{ int n1,n2;
scanf("%d",&n2);
while(n2!=0)
{ n1=n2%10;
n2=n2/10;
printf("%d",n1);
}
}
程序運行後,如果從鍵盤上輸入1298,則輸出結果為 8921 。
3.若輸入字母b,程序輸出結果為 b, B ;若輸入字元*,程序將怎樣 等待重新輸入 。
#include<stdio.h>
main()
{char c1, c2;
c1=getchar();
while(c1<97||c1>122)
c1=getchar();
c2=c1-32;
printf("%c, %c\n",c1, c2);
}
4.用以下程序計算1到100的整數的累加和。
main()
{ int i=1, sum= 0 ;
for( ; i<=100 ; )
{sum+=i;
i++;
}
printf("sum=%d\n", sum );
}
5.以下程序的功能是:從鍵盤上輸入若干個學生的成績,統計並輸出最高成績和最低成績,當輸入負數時結束。請填空。
main()
{ float x, amax, amin;
scanf(「%f」,&x);
amax=x;
amin=x;
while( x>=0 )
{if(x>amax) amax=x;
if( x<amin ) amin=x;
scanf(「%f」,&x);
}
printf("amax=%f\namin=%f\n",amax, amin);
}
Ⅱ 怎麼編寫c語言程序完成輸入a,b,c三個值並輸入三者之和
#include<stdio.h>
void main(){
int a,b,c,sum;
printf("請輸入變數a的值:");
scanf("%d",&a);
printf("請輸入變數b的值:");
scanf("%d",&b);
printf("請輸入變數c的值:");
scanf("%d",&c);
sum=a+b+c;
printf("a、b、c的和是:%d!\n",sum);
}
Ⅲ 編程:用C語言求a、b、c三個數之和
#include
"stdio.h"
#include
<Windows.h>
void
main()
{
int
a=0,b=0,c=0,sum=0;
printf("請你輸入三個數,例如:1
2
3\n");
scanf("%d
%d
%d",&a,&b,&c);
sum=a+b+c;
printf("\n計算結果的:%d\n",sum);
system("pause");
}
Ⅳ c語言 輸入三個數求它們之和
s=floor(1.0*(a+b+c)/3);
scanf("%d
%d
%d",&a,&b,&c);
換一下位置就可以了。先輸入abc值。
scanf("%d
%d
%d",&a,&b,&c);
s=floor(1.0*(a+b+c)/3);
Ⅳ 編程:用C語言求a、b、c三個數之和
#include<stdio.h>
void main()
{
int a=?,b=?,c=?;/*?號填寫數值*/
printf("a b c 三數之和為:%d",a+b+c);
}
Ⅵ 用C語言編程輸入三個整數數,求它們的和及平均值
1、#include<stdio.h>intmain()
2、{inta,b,c;scanf("%d%d%d"盯拆,&a,&b,&c);
3、intsum=a+b+c;
4、printf("和:%d",sum);
5、printf("平均值:%f",sum/3.0);
6、return0
Ⅶ 我想問下c語言裡面運算結果abc什麼意思,然後第二張圖的ab啥意思,圈出來的式子的意思
轉義字元「\101」就表示第65位ascii碼值表示的字元A。八進制101等於65
同理「\x42」表示字元B。十六進制42等於66
第二張圖中的計算式很容易理解啊,因為字元可以按照ascii碼對應的數值來進行計算
比如c1是"A",c2=c1+1,則c2就是"B"。如果c2=c1+32,那麼c2就是「a」
這是因為A對應65,B對應66,a對應97
所以圖片里的c1和c2按照這樣計算就是對應的「A」和「B」了
Ⅷ C語言程序設計~從鍵盤輸入3個數,計算3個數的和以及平均數,小弟才接觸什麼都不懂,望高手指點
沒大的錯誤,如果你想要更精確的結果的話,建議使用float或double:
#include
<stdio.h>
main()
{
int
a,b,c,d,e;
double
x,
y;
scanf("%d%d%d%d%d",&a,&b,&c,&d,&e);
x=a+b+c+d+e;
y=x/5;
printf("
%.2f
\n",y);
}