B092

01-程序填空题 田少松, 软件154 212浏览

所属年份:2010.9;2012.3

给定程序中,函数fun的功能是:把形参s所指字符串中最右边的n个字符复制到形参t所指字符数组中,形成一个新串。若s所指字符串的长度小于n,则将整个字符串复制到形参t所指字符数组中。
例如,形参s所指的字符串为:abcdefgh,n的值为5,程序执行后t所指字符数组中的字符串应为:defgh。
请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。

注意:部分源程序在文件BLANK1.C中。
不得增行或删行,也不得更改程序的结构!

#include  <stdio.h>
#include  <string.h>
#define   N   80
void fun(char  *s, int  n, char  *t)
{
    int len,i,j=0;
    len=strlen(s);
    /**********found**********/
    if(n>=len) strcpy(__1__);
    else
    {
        /**********found**********/
        for(i=len-n; i<=len-1; i++)  t[j++]= __2__ ;
        /**********found**********/
        t[j]= __3__ ;
    }
}

main()
{
    char  s[N],t[N];
    int  n;
    printf("Enter a string:  ");
    gets(s);
    printf( "Enter n:");
    scanf("%d",&n);
    fun(s,n,t);
    printf("The string t :  ");
    puts(t);
}

【参考答案】

(1)t,s  
(2)s[i]  
(3)0或'\0'

【解题思路】
本题是在矩阵中找出在行上最大、在列上最小的那个元素。
填空1:当给定的长度n大于该字符串s的长度,那么把该字符串直接拷贝到t就可以了,所以应填t,s。
填空2:使用for循环语句,把最右边n个字符依次添加到t中,所以应填s[i]。
填空3:字符串操作结束,需要给t加一个字符串结束符,所以应填0或’\0’。