[填空题]
阅读以下说明和C程序,填补空缺。 [说明]
下面的程序按照以下规则输出给定名词的复数形式。 (1)若名词以“y”结尾,则删除y并添加“ies”。 (2)若名词以“s”、“ch”或“sh”结尾,则添加“es”。 (3)其他所有情况,直接添加“s”。 [C程序] #include<stdio.h> #include<string.h> char *plural(char *word) { int n; char *pstr; n=strlen(word); /*求给定单词的长度*/ pstr=(char*)malloc(n+3); /*申请给定单词的复数形式存储空间*/ if(!pstr || n<2) return NULL; strcpy(pstr, word); /*复制给定单词*/ if( (1) ) { pstr[n-1]=’i’; pstr[n]=’e’; pstr[n+1]=’s’; (2) ; } else if(pstr[n-1]==’s’||pstr[n-1]==’h’ &&( (3) )) { pstr[n]=’e’; pstr[n+1]=’s’; pstr[n+2]=’/0’; } else {pstr[n]=’s’; pstr[n+1]=’/0’; } (4) ; } main( ) { int i; char *ps; char wc[9][10]= {"chair", "dairy", "boss", "circus", "fly", "dog", "church", "clue", "dish"); for(i=0; i<9; i++) { ps= (5) ; printf("%s: %s/n", wc[i], ps); /*输出单词及 [填空题]
阅读以下说明和C语言程序,填补空缺。 [说明]
某电信公司记录了每个用户的详细通话情况(每次通话数据记录在一行),现将某用户某月的通话数据存入一个文本文件“dial.txt”中,其数据格式如下: 拨入或拨出标记通话开始时间通话结束时间对方号码 注1:数据字段以一个空格作为分隔符。 注2:拨入和拨出标记均为小写字母。拨入标记为“i”,表示其他用户呼叫本机,本机用户不需付费;拨出标记为“o”,表示本机呼叫其他用户,此时本机用户需要付费。 注3:通话开始和结束时间的格式均为:HH:MM:SS。其中HH表示小时,取值00~23;MM表示分钟,取值00~59;SS表示秒,取值00~59。从通话开始到结束这段时间称为通话时间,假定每次通话时间以秒为单位,最短为1秒,最长不超过24小时。 注4:跨月的通话记录计入下个月的通话数据文件。 例如“o 23:01:12 00:12:15…”表示本次通话是本机呼叫其他用户,时间从23时01分12秒至次日的0时12分15秒,通话时间为71分03秒。 下面程序的功能是计算并输出该用户本月电话费(单位:元)。 通话计费规则为: (1)月通话费按每次通话费累加; (2)每次的通话费按通话时间每分钟0.08元计算,不足1分钟时按1分钟计费。 对于每次的拨出通话,程序中先分别计算出通话开始和结束时间相对于当日0点0分0秒的时间长度(以秒为单位),然后算出本次通话时间和通话费。 例如,若输入文件dial.txt的数据如下所示,则输出fee=7.44。 o 14:05:23 14:11:25 82346789 i 15:10:00 16:01:15 13890000000 o 10:53:12 11:07:05 63000123 o 23:01:12 00:12:15 13356789001 [C语句程序代码] #include<stdio.h> FILE *fin; int main( ) { char str[80]; int h1, h2, m1, m2, [填空题]
阅读以下说明和C语言函数,填补空缺。 [说明]
已知1900年1月1日是星期一,下面的函数count_5_13(int year)用于计算给定的年份year中有几个“黑色星期五”。“黑色星期五”指既是13日又是星期五的日期。 函数count_5_13(int year)首先算出年份year的1月13日是星期几,然后依次计算每个月的13日是星期几,若是星期五,则计数。 程序中使用了函数isLeapYear(int year),其功能是判断给定年份是否为闰年,返回值为1(或0)分别表示year是(或不是)闰年。 [C语言函数] int Count_5_13(int year) { int date; /*date为0表示星期日,为1~6分别表示星期一至星期六*/ long days=0; /*days记录天数*/ int m, y, c=0; /*c用于表示黑色星期五的个数*/ if(year<1900) return-1; /*计算从1900年1月1日起,至给定年份year的1月13日间隔的天数*/ days=12; for(y=1900; y<year; y++) { days +=365; if (iSLeapYear(Y)) (1) ; } date=((days%7)+1)%7; /*算出给定年份year的1月13日是星期几+/ c=( (2) )1:0; for(m=1; (3) ; m++) { switch(m) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: days=31; break; case 4: case 6: case 9: case 11: days=30; break; case 2: days=28; 我来回答: 提交
|