习题参考答案 习题一 1./*在C语言中,下列标识符中哪些是合法的,哪些不合法?”*/
合法:total, _debug, Counter1, begin_
不合法:Large&Tall
2. /*写出流程图,求1~100中能被6整除的所有整数之和*/
3./*写出源程序,求1~100中能被6整除的所有整数之和”。*/
#include<stdio.h>
void main()
{
int sum=0, i;
for(i=1; i<=100; i++)
if( i%6==0) sum =sum+i;
sum);
printf(“sum=%d”,
}
4./*画流程图,判别整数n是否是素数*/
习题参考答案 习题十
1.选择题
(1) A
(2) C(由于p指向x, 等式p≡&x, *p≡x成立. 故&*p≡&x≡p)
(3) B (int c[]={1, 7, 12}; → c[0]=1, c[1]=7, c[2]=12. 而k=c, 即k指向数组c的首元素c[0]。printf(“…”, *++k); 输出参数*(++k)的值是*(k+1), 即c[1] )
(4) D (对字符数组只能在定义的同时赋初值,但不能在定义之后再用‘=’赋值)
(5) D(*p[3]是由3个整型指针组成的数组,p是数组名,代表该数组的基地址,是地址常量,不能对p赋值,故A,C错。*p代表p[0]这个指针,a[0]是普通整型变量,两者不应互相赋值,故B错。p[0]=&a[0]或p[0]=a,都是正确的,作用是令p[0]这个指针指向数组a的首元素a[0])
(6) D ( 指针数组元素p[3]是一个指针,指向a[3*3]=a[9], 即*p[3]==a[9] 而二维数组元素p[3][2]= *(p[3]+2)=*(&a[9]+2)=*(&a[11])=a[11])
2./*写输出结果*/
(1) 3,2,5 # 3,3,4 #
注: z是全局变量,它在p()中有效,但在main()中另有与它同名的局部变量,所以在main()中无效。 main()和p()中分别定义了各自的局部变量x,y。在void p( int *x, int y)中x是指针形式,表示按地址传递,则p中的 *x就是main()中的x;另一形参y是普通变量形式,p对y的修改不影响main()中的y的值。
变量在函数p()中的取值在main()中的取值
x 2→3 (++*x) 3(受p()影响)
y 3→2(y--) 3 (不受p()影响)
z 4→5 (z=*x+y=3+2) 4(不受p()影响)
(2) udent
注:s+2=&s[2], 当作为printf()中对应“%s”的输出参数时,表示从s[2]开始输出,直到字符串结束)
(3) HappyNewYear
注: 1. for(s=pa, n=0; *s!='\0'; ++s, ++n); //求字符串pa的有效长度n, 相当于:
n=0;
*s!=’\0’;
++s)
s=pa;
for(
++n;
/
/ n=12
2. for(s=pa, i=0; i<n; putchar(*s++), ++i);// 逐个输出指针s所指向字符串pa的各字符,相当于
s=pa;
for( i=0; i<n; i++) {
);
putchar(
*s
s++; //指针后移一位
}
(4) our
注:char *st[]={"one", "two", "three","four"}; 定义了长度为4的字符指针数组,如下:
s[][0] st[][1] st[][2] st[][3] st[][4] s[][5]
st[0] o n e \0
st[1] t w o \0
st[2] t h r e e \0
st[3] f o u r \0
st[3]+1
表达式:*(st+3)+1= st[3]+1, 这是一个地址值,即指向st[3]字符串”four”的第1号字符’o’
由于输出格式是字符串‘%s’, 所以输出的字符串是从st[3]+1这个地址开始,到遇见’\0’为止
(5)<;略,不做要求>
3./*填空题*/
(1) for (i=0; s[i]!=’\0’; i++)
(2)void f( char *s 或 char s[] )
{ int i=0;
while(s[i]) i++; //令i指向字符串的最后一个有效字符, 即while( s[i]!=’\0’) i++;
for( ; i>=0; i- -) printf("%c", s[i]); //逆序输出
}
4.定义函数search(int list[], int n, int x), 在长度为n的数组list中查元素x, 并返回x在list中的下标。如果x在list
中不存在,则返回-1.
解法1:使用break语句
int search( int list[], int n, int x)
{int i, index=-1; //index: x在list中的下标,目前尚未到,因此初始化为-1
for ( i=0; i<n; i++) //逐个对比list[i]与x, 相等则跳出循环,否则继续往下比较,直到整个数组比完
)
x
{
if(
list[i]==
index=i;
break;
}
return index; //返回x在list中的下标
}
解法2:使用return语句—当程序执行到return语句,将提前结束循环,并结束函数search(),返回主函数main() int search( int list[], int n, int x)
{int i ;
for ( i=0; i<n; i++) //逐个对比list[i]与x, 相等则跳出循环,否则继续往下查,直到遍整个数组if( list[i]== x ) return i;
return -1; //当for循环正常结束,说明遍整个数组都不到x, 返回-1
}
5.定义函数void sort(int a[], int n), 用选择法对a排序(升序)。自定义主函数main().
void sort( int a[], int n) //a数组名,n数组长度
{int i, j, index, t;
for ( i=0; i<n-1; i++){
index=i;
for( j=i+1; j<n; j++)
if( a[index] > a[ j] ) index=j;
t=a[i]; a[i]=a[index]; a[index]=t;
}
#include<stdio.h>
void main()
{ int a[10], i;
printf(“Input 10 integers:”);
for( i=0; i<10; i++) scanf(“%d”, &a[i]);
sort(a,10);
printf(“After sorted:”);
for(i=0; i<10; i++) printf(“%d “, a[i]);
putchar(‘\n’);
}
6. 编写程序:输入5个字符,输出其中最长的字符串void sort( int a[], int n) //a 数组名,n 数组长度
#include<stdio.h>
字符串复制函数#include<string.h>
void main()
{ int i, len, max_len;
char s[80], max_s[80];
printf(“Input 5 strings:”);
gets( max_s); //输入第1个字符串,暂作最长字符串
max_len= strlen(max_s);
for( i=1; i<5; i++) { //输入剩余的4个字符串,并与当前的最长字符串做比较
gets( s );
len= strlen( s);
if ( len > max_len ) {
strcpy( max_s, s); //注意:不能写成 max_s =s;
max_len= len;
}
}
printf(“The max_s is:”);
puts( max_s );
}
7. /*编写函数delchar(s,c). 删除字符串s 中出现的所有c 字符。请同时编写主函数*/
实例:s=”welcome!” c=’e’ s 初始值
w e l c o m e ! \0
w e l c o m e ! \0 当s[i]==c, 它后面的字符从’l’开始到’\0’为止,各前进一位 删1次后
w l c o m e ! \0 i 继续前进,直到遇见下一个c, 将后面的字符各前进1位 删2次后 w l c o m ! \0
i 继续前进,直到遇见结束字符’\0’ ,结束整个循环
i i i
分析:
1.循环条件是 s[i]!=’\0’
2.如何将i 后面若干字符各前进一位?--利用字符串复制函数和 字符子串
s 代表完整的字符串,而s+i 代表从s[i]开始、到’\0’结束的子串。
将子串s+i+1复制给子串s+i, 即 实现i 后各字符前进一位strcpy( s+i, s+i+1)
#include<stdio.h>
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论