习题一
一、名词解释
(1)程序P1 (2)程序设计P1 (3)机器语言P1(4)高级语言P2
(5)汇编程序P3 (6)编译程序P4 (7)算法P5(8)结构化程序设计方法P10
二、简答题
1. 设计程序时应遵循哪些基本原则?P4
答:正确性、可靠性、简明性、有效性、可维护性、可移植性。
2. 算法具有哪些特点?
答:有穷性、确定性、有效性、有零个或多个输入、有一个或多个输出。
3. 算法的表示形式有哪几种?
答:自然语言、伪代码、传统流程图、N-S流程图、计算机语言。
4. 结构化程序设计方法的三种基本结构是什么?
答:顺序结构、选择结构和循环结构。
5. 传统流程图与N-S流程图最大的区别是什么?
答:N-S流程图去掉了在传统流程图中常用的流程线,使得程序的结构显得更加清晰、简单。
三、用传统流程图或N-S流程图表示求解以下问题的算法。
1. 从键盘输入10个整数,求出其中的最小数并输出。
2. 求1 2 3 … 100的值。
3. 求10~50的所有素数之和。
4. 求下列分段函数的值。
四、请参照本章例题,编写一个简单的C程序,输出以下三行信息。
**************************
Yangtze University
**************************
#include <stdio.h>
void main()
{
printf("**************************\n")
printf("Yangtze University\n")
printf("**************************\n")
}
习题二
一、选择题
1~10: B C D C D D B C A A
11~20: D A C D B D B A C D
二、填空题
1.字母 L 或字母 l
2. %c(或字符) 、%d(或整数)
3. 在程序运行过程中,其值可以在一定的范围内变化的量
4. '\0'
5. 小数形式、 指数形式
6. 关键字 、 预定义标识符 、 用户标识符
7. 字母 、 数字 、 下划线 、 数字
8. 18
9. 2 、 1 、 30
10. 双精度实数或double
11. 赋值 、 逗号 、 20 、 20 、 20 、 4
12. 4 、 4
习题三
一、选择题
1~10: B C C B C C C D C C
注:第4题答案D为: 10 22↙
33↙
二、填空题
1. printf 、 scanf
2. h
3. "]"
4. '\0'
5. e 、 E
6. 6
7. s 、 c
8. *
9. - 、
10. i
三、编程题
1. 编写程序,从键盘输入一个以秒为单位的时间数,将其换算成几小时几分几秒,然后进
行输出。例如输入的时间为4258秒,则输出结果为:1小时10分58秒。
#include <stdio.h>
void main()
{
int x,h,m,s
scanf("%d",&x)
h=x/3600m=x600/60s=x`
printf("%ds=%d:%d:%d!\n",x,h,m,s)
}
2. 编写程序,读入三个整数给变量a、b、c,然后交换它们中的数,把a中原来的值给b,
把b中原来的值给c,把c中原来的值给a。
#include <stdio.h>
void main()
{
int a,b,c,t
printf("input a b c:")
scanf("%d%d%d",&a,&b,&c)
printf("a=%d,b=%d,c=%d\n",a,b,c)
t=aa=cc=bb=t
printf("a=%d,b=%d,c=%d\n",a,b,c)
}
习题四
一、填空题
1. 1 、 0
2. ! % + <= != && || =
3. x==0
4. 0 、 2
5. 20 、 0 、 0
二、选择题
1~7:D D C A D D C
三、程序阅读题
1. 595959
2. 0.500000
3. 1
4. 2
5. 6
6. a=2,b=1
7. pass
warn
8.1
四、编程题
1. 设a为整型变量且其值大于零,请将以下if语句改写成switch语句。
if(a<60) m=1
else if(a<70) m=2
else if(a<80) m=3
else if(a<90) m=4
else m=5
方法1
#include <stdio.h>
void main()
{
int a,m
scanf("%d",&a)
switch(a/10)
{
case 0:case 1:case 2:case 3:
case 4:case 5:m=1break
case 6:m=2break
case 7:m=3break
case 8:m=4break
default:m=5break
}
printf("m=%d\n",m)
}
方法2
#include <stdio.h>
void main()
{
int a,m
scanf("%d",&a)
m=0
switch(a/10)
{
default:m
case 8:m
case 7:m
case 6:m
case 5:case 4:case 3:case 2:
case 1:case 0:m
}
printf("m=%d\n",m)
}
2. 编写程序,从键盘输入一个整数,打印出它是奇数还是偶数。
#include <stdio.h>
void main()
{
int a
scanf("%d",&a)
if(a%2==1)
printf("%d is a odd number!\n",a)
else
printf("%d is a even number!\n",a)
}
3. 编写程序,从键盘输入一个字符,判别它是否是小写字母,如果是,将它转换为大写字母;如果不是,不转换。然后输出最后得到的字符。
#include <stdio.h>
void main()
{
char ch
scanf("%c",&ch)
if(ch>='a' &&ch<='z')
ch=ch-32
printf("%c\n",ch)
}
4. 编写程序,从键盘输入一个不多于4位的正整数,打印出它是几位数。
#include <stdio.h>
void main()
{
int x,n
scanf("%d",&x)
if(x>1000) n=4
else if(x>100) n=3
else if(x>10) n=2
else n=1
printf("%d\n",n)
}
5. 当一个人的月收入在3500元以下时免税;月收入在3500元到5000元之间时,超过3500的部分纳税3%;月收入在5000元以上时,3500至5000之间的部分纳税3%,超过5000的部分纳税10%。编写程序从键盘输入月收入income,计算并输出应交税款tax。
#include <stdio.h>
void main()
{
int income
float tax
scanf("%d",&income)
if(income<=3500) tax=0
else if(income<=5000) tax=0.03*(income-3500)
else tax=0.03*(5000-3500) 0.10*(income-5000)
printf("tax=%f\n",tax)
}
6. 回文是指正读和反读都一样的数或字符串。例如:12321、55455、35553等都是回文。请编写一个程序,从键盘上读取一个包含五位数字的长整数,并判断它是否是回文。(提示:用除法运算和求余运算把一个数的个位、十位、百位、千位等分别分离出来。)
#include <stdio.h>
void main()
{
long x
int a,b,d,e
scanf("%ld",&x)
a=x/10000
b=x000/1000
d=x0/10
e=x
if(a==e &&b==d)
printf("%ld is huiwen!\n",x)
else
printf("%ld is not huiwen!\n",x)
}
习题五
一、阅读题
1.8
2.4321
3.X
4.-1
5.23
6.52
7.5
8.3
二、填空题
1. 18
2. 2
3. b=i 1
4. 17
5. i<=9、 j%3!=0
6. d=1.0 、 k=k 1 、 k<=10
三、选择题
1~8:A D D A B D D A
四、编程题
1. 编写程序,打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字的立方之和等于该数本身。例如,407是一个“水仙花数”,因为407=43 03 73。(注:若将题意改为打印出最大的或最小的“水仙花数”,则应将循环语句作如何调整?)。
#include <stdio.h>
void main()
{
int a,b,c,k
for(k=100k<=999k )
//求最大的“水仙花数”改用:for(k=999k>=100k--)
{
a=k/100b=k/10c=k
if(k==a*a*a b*b*b c*c*c)
{
printf("]",k)
//求最大或最小”水仙花数”时增加一个语句:break
}
}
printf("\n")
}
2. 编写程序,输出1980~2880年所有闰年的年号。每输出5个年号换一行。
#include <stdio.h>
void main()
{
int k,flag,n=0
for(k=1980k<=2880k )
{
flag=(k%4==0)&&(k0!=0)||(k@0==0)
if(flag)
{
printf("]",k)
n
if(n==0)
printf("\n")
}
}
printf("\n")
}
3. 编写程序,求1-3 5-7 …-99 101的值。
#include <stdio.h>
void main()
{
int n,t=1,s=1
for(n=3n<=101n =2)
{ t=-ts=s t*n}
printf("s=%d\n",s)
}
4. 编写程序,计算并输出下列级数的前n项之和Sn。n的值从键盘输入。
#include <stdio.h>
void main()
{
int fz,fm,n,i
float s,t
fz=2fm=1s=0
scanf("%d",&n)
for(i=1i<=ni )
{
t=(1.0*fz)/fm
s=s t
fz=fz fm
fm=fz-fm
}
printf("s=%f\n",s)
}
5.编写程序,求e的值e=1 1/1! 1/2! 1/3! 1/4! … 1/n!
#include <stdio.h>
void main()
{
int n,i
float t,fm=1,e=1
scanf("%d",&n)
for(i=1i<=ni )
{ fm=fm*it=1.0/fm e=e t }
printf("n=%d,e=%f\n",n,e)
}
6. 已知某球从80米高度自由落下,落地后反复d起,每次d起的高度都是上次高度的一半。求此球8次落地所经过的总路程。
#include <stdio.h>
void main()
{
int n
float s=80,h=s/2
for(n=2n<=8n )
{
s=s 2*h
h=h/2
}
printf("s=%f\n",s)
}
7. 用牛顿迭代法求高次方程f(x)=2x3-4x2 5x-18=0的根(约为2.466)。
注:牛顿迭代公式为:x2=x1-f(x1)/f’(x1),其中f’(x1)为导函数在点x1的值。
#include <stdio.h>
#include <math.h>
void main()
{
float x,f,f1
x=8 // x的初值可为任意值
do
{ f=2*x*x*x-4*x*x 5*x-18f1=6*x*x-8*x 5x=x-f/f1
}while(fabs(f)>0.00001)
printf("x=%f,f=%f\n",x,f)
}
8. 有这样一些真分数:其分子和分母都是两位正整数,且分子的个位数与分母的十位数相同,如果把该分数的分子的个位数与分母的十位数同时去掉,所得到的新的分数正好与原分数的值相等,如26/65=2/5。试编程求出所有满足上述条件的真分数。
#include <stdio.h>
void main()
{
int a,b,c // 设这个分数为ab/bc
for(a=1a<=9a )
for(b=1b<=9b )
for(c=1c<=9c )
if((a<c)&&(1.0*a/c==(a*10.0 b)/(b*10.0 c)))
printf("%d/%d=%d%d/%d%d=%f\n",a,c,a,b,b,c,1.0*a/c)
}
9. 编写程序,求数列:1,(1 1/2),(1 1/2 1/3),(1 1/2 1/3 1/4),(1 1/2 1/3 1/4 1/5),…的前10项之和。
#include <stdio.h>
void main()
{
float s,t
int i
s=0,t=0
for(i=1i<=10i )
{ t=t 1.0/is=s t}
printf("s=%f\n",s)
}
10. 编写程序,求3到100之间的所有素数之和。
#include <stdio.h>
void main()
{
int s,i,k,flag
s=0
for(i=3i<=100i )
{
flag=1
for(k=2k<ik )
if(i%k==0)
{ flag=0break}
if(flag)
{ s=s iprintf("M",i)}
}
printf("\nsum=%d\n",s)
}
11. 编写程序,求Fibonacci数列中大于800的最小的一个数(结果为987)。
#include <stdio.h>
void main()
{
int f1=1,f2=1,f3
while(f3<=800)
{
f3=f1 f2
f1=f2
f2=f3
}
printf("Fibonacci数列中大于800的最小数是]\n",f3)
}
习题六
一、选择题
1~10:D D C B A B C D C D
11~20:A B B C C D C A B B
21~30:B B D D D D C D C A
注:第16题答案C为:字符串"SHORT"与"SHORT "相等
第19题题目为:已知:char str1[10],str2[10]={"books"}则在程序中能够将字符串
"books"赋给数组str1的正确语句是 。
第21题题目为:设有:char str1[20]="abcde",str2[20]="xyz"则执行语句:
printf("%d",strlen(strcpy(str1,str2))的结果是 。
第28题答案D为: aaaa
bbbb
cccc dddd
二、填空题
1.9 、 0
2.先行后列
3.
习 题 1
1.1 填空题
1.函数
2.主函数main();主函数main()
3.主函数main()
4.函数首部;函数体
5.{;}
6.顺序结构;选择结构;循环结构
7..c;.obj;.exe
1.2 思考题
1.答:结构化程序设计是指,为使程序具有一个合理的结构以保证程序正确性而规定的一套如何进行程序设计的原则。顺序结构,选择结构,循环结构
2.答:算法是对具体问题求解步骤的一
种描述。计算机算法的表达工具通常采用以下几种方法:①用自然语言表示算法;②用流程图表示算法;③用伪代码表示算法;④用程序设计语言表示算法。
3.略
4.略
5.略
1.3 编程题
1.答:
#include "stdio.h"
main()
{ float a=10, b=20, h=5, s
s=(a+b)*h/2
printf("s=%f " , s )
}
4.3 函数的调用与参数如果一个函数要使用参数,它就必须定义接受参数值的变量。
4.3.1 形式参数与实际参数
函数定义时填入的参数我们称之为形式参数,简称形参,它们同函数内部的局部变量作用相同。形参的定义是在函数名之后和函数开始的花括号之前。
调用时填入的参数,我们称之为实际参数,简称实参。
必须确认所定义的形参与调用函数的实际参数类型一致,同时还要保证在调用时形参与实参的个数出现的次序也要一一对应。如果不一致,将产生意料不到的结果。与许多其它高级语言不同,(是健壮的,它总要做一些甚至你不希望的事情,几乎没有运行时错误检查,完全没有范围检测。作为程序员,必须小心行事以保证不发生错误,安全运行。
4.3.2 赋值调用与引用调用
一般说来,有两种方法可以把参数传递给函数。第一种叫做“赋值调用”(call by value),这种方法是把参数的值复制到函数的形式参数中。这样,函数中的形式参数的任何变化不会影响到调用时所使用的变量。
把参数传递给函数的第二种方法是“引用调用”(call by reference)。这种方法是把参数的地址复制给形式参数,在函数中,这个地址用来访问调用中所使用的实际参数。这意味着,形式参数的变化会影响调用时所使用的那个变量(详细内容请参见后续章节)。
除少数情况外,C语言使用赋值调用来传递参数。这意味着,一般不能改变调用时所用变量的值。请看例4 - 9。
[例4 - 9]
main ( )
{
int t =10;
printf("%d %d ",sqr(t),t)/* sqr(t)是函数调用,t是实参* /
}
int sqr(x) /* 函数定义,x是形式参数* /
int x;
{
x = x * x
return (x)
}
在这个例子里,传递给函数sqr( )的参数值是复制给形式参数x的,当赋值语句x = x * x执行时,仅修改局部变量x。用于调用sqr( )的变量t,仍然保持着值10。
执行程序:
100 10
切记,传给函数的只是参数值的复制品。所有发生在函数内部的变化均无法影响调用时使用的变量。
4.4 递归
C语言函数可以自我调用。如果函数内部一个语句调用了函数自己,则称这个函数是“递归”。递归是以自身定义的过程。也可称为“循环定义”。
递归的例子很多。例如定义整数的递归方法是用数字1,2,3,4,5,6,7,8,9加上或减去一个整数。例如,数字1 5是7 + 8;数字2 1是9 + 1 2; 数字1 2是9 + 3。
一种可递归的计算机语言,它的函数能够自己调用自己。一个简单的例子就是计算整数阶乘的函数factor( )数N的阶乘是1到N之间所有数字的乘积。例如3的阶乘是1×2×3,即是6。
factor( )和其等效函数fact( )如例4 - 1 0所示。
[例4 - 1 0 ]
factor(n) /* 递归调用方法* /
int n;
{
int answer
if (n==1)
return (1)
answer=factor(n-1) * n; /* 函数自身调用* /
return(answer)
}
[例4 - 11 ]
fact(n) /* 非递归方法* /
int n
{
int t,a n s w e r
answer = 1
for (t=1t <= nt ++)
answer = answer * t
return(answer)
}
非递归函数fact( )的执行应该是易于理解的。它应用一个从1开始到指定数值结束的循环。
在循环中,用“变化”的乘积依次去乘每个数。
factor( )的递归执行比fact( )稍复杂。当用参数1调用factor( )时,函数返回1;除此之外的其它值调用将返回factor(n-1) * n这个乘积。为了求出这个表达式的值,用( n - 1)调用factor( )一直到n等于1,调用开始返回。
计算2的阶乘时对factor( )的首次调用引起了以参数1对factor( )的第二次调用。这次调用返回1,然后被2乘(n的初始值),答案是2(把printf( )语句插入到factor ( )中,察看各级调用及其中间答案,是很有趣的)。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)