
浙大版《C语言程序设计(第4版)》题目集
二三hhh
代码小白成长
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
浙大版《C语言程序设计(第4版)》题目集 习题11-8 单链表结点删除
题目要求:本题要求实现两个函数,分别将读入的数据存储为单链表、将链表中所有存储了某给定值的结点删除。链表结点定义如下:struct ListNode { int data; ListNode *next;};函数接口定义:struct ListNode *readlist();struct ListNode *deletem( struct ListNode *L, int m );函数readlist从标准输入读入一系列正整数,按照读入顺序建立单链表。当读到−1时表示输入原创 2021-08-11 21:12:21 · 634 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-7 奇数值结点链表
题目要求:本题要求实现两个函数,分别将读入的数据存储为单链表、将链表中奇数值的结点重新组成一个新的链表。链表结点定义如下:struct ListNode { int data; ListNode *next;};函数接口定义:struct ListNode *readlist();struct ListNode *getodd( struct ListNode **L );函数readlist从标准输入读入一系列正整数,按照读入顺序建立单链表。当读到−1时表示输入结束,函数原创 2021-08-11 21:12:09 · 339 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-6 查找子串
题目要求:本题要求实现一个字符串查找的简单函数。函数接口定义:char *search( char *s, char *t );函数search在字符串s中查找子串t,返回子串t在s中的首地址。若未找到,则返回NULL。裁判测试程序样例:#include <stdio.h>#define MAXS 30char *search(char *s, char *t);void ReadString( char s[] ); /* 裁判提供,细节不表 */int main()原创 2021-08-10 19:56:33 · 387 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-5 指定位置输出字符串
题目要求:本题要求实现一个函数,对给定的一个字符串和两个字符,打印出给定字符串中从与第一个字符匹配的位置开始到与第二个字符匹配的位置之间的所有字符。函数接口定义:char *match( char *s, char ch1, char ch2 );函数match应打印s中从ch1到ch2之间的所有字符,并且返回ch1的地址。裁判测试程序样例:#include <stdio.h>#define MAXS 10char *match( char *s, char ch1, ch原创 2021-08-10 19:00:25 · 757 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-4 字符串的连接
题目要求:本题要求实现一个函数,将两个字符串连接起来。函数接口定义:char *str_cat( char *s, char *t );函数str_cat应将字符串t复制到字符串s的末端,并且返回字符串s的首地址。裁判测试程序样例:#include <stdio.h>#include <string.h>#define MAXS 10char *str_cat( char *s, char *t );int main(){ char *p;原创 2021-08-10 16:05:23 · 892 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-3 计算最长的字符串长度
题目要求:本题要求实现一个函数,用于计算有n个元素的指针数组s中最长的字符串的长度。函数接口定义:int max_len( char *s[], int n );其中n个字符串存储在s[]中,函数max_len应返回其中最长字符串的长度。裁判测试程序样例:#include <stdio.h>#include <string.h>#include <stdlib.h>#define MAXN 10#define MAXS 20int max_le原创 2021-08-10 15:53:39 · 253 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-2 查找星期
题目要求:本题要求实现函数,可以根据下表查找到星期,返回对应的序号。序号 星期0 Sunday1 Monday2 Tuesday3 Wednesday4 Thursday5 Friday6 Saturday函数接口定义:int getindex( char *s );函数getindex应返回字符串s序号。如果传入的参数s不是一个代表星期的字符串,则返回-1。裁判测试程序样例:#include <stdio.h>#include <string.h>原创 2021-08-09 22:24:30 · 303 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题11-1 输出月份英文名
题目要求:本题要求实现函数,可以返回一个给定月份的英文名称。函数接口定义:char *getmonth( int n );函数getmonth应返回存储了n对应的月份英文名称的字符串头指针。如果传入的参数n不是一个代表月份的数字,则返回空指针NULL。裁判测试程序样例:#include <stdio.h>char *getmonth( int n );int main(){ int n; char *s; scanf("%d", &n);原创 2021-08-09 21:29:59 · 347 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 练习11-4 字符定位(最后一次找到的字符)
题目要求:本题要求定义一个函数,在字符串中查找字符,并定位在最后一次找到的位置。函数接口定义:char * match(char *s, char ch);其中s是字符串首地址,ch是要查找的字符。要求函数在字符串s中查找字符ch,如果找到,返回最后一次找到的该字符在字符串中的位置(地址);否则,返回空指针NULL。裁判测试程序样例:#include <stdio.h> char *match(char *s, char ch); int main(void ){原创 2021-08-09 21:18:00 · 7242 阅读 · 1 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-11 有序表的增删改查操作
题目要求:首先输入一个正整数N(1≤N≤1000)和一个无重复元素的、从小到大排列的、N个元素的有序表,然后在屏幕上显示以下菜单(编号和选项)。[1] Insert[2] Delete[3] Update[4] Query[Other option] End用户可以反复对该有序表进行插入、删除、修改和查找操作,也可以选择结束。当用户输入编号1~4和相关参数时,将分别对该有序表进行插入、删除、修改和查找操作,输入其他编号,则结束操作。本题要求实现4个函数,分别在有序表(数组)中插入、删除、修原创 2021-08-06 19:28:20 · 2684 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-8 递归实现顺序输出整数
题目要求:本题要求实现一个函数,对一个整数进行按位顺序输出。函数接口定义:void printdigits( int n );函数printdigits应将n的每一位数字从高位到低位顺序打印出来,每位数字占一行。裁判测试程序样例:#include <stdio.h>void printdigits( int n );int main(){ int n; scanf("%d", &n); printdigits(n); retur原创 2021-08-05 20:55:38 · 211 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-7 十进制转换二进制
题目要求:本题要求实现一个函数,将正整数n转换为二进制后输出。函数接口定义:void dectobin( int n );函数dectobin应在一行中打印出二进制的n。建议用递归实现。裁判测试程序样例:#include <stdio.h>void dectobin( int n );int main(){ int n; scanf("%d", &n); dectobin(n); return 0;}/* 你的代码将被嵌在原创 2021-08-05 20:39:42 · 351 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-6 递归求Fabonacci数列
题目要求:本题要求实现求Fabonacci数列项的函数。Fabonacci数列的定义如下:f(n)=f(n−2)+f(n−1) (n≥2),其中f(0)=0,f(1)=1。函数接口定义:int f( int n );函数f应返回第n个Fabonacci数。题目保证输入输出在长整型范围内。建议用递归实现。裁判测试程序样例:#include <stdio.h>int f( int n );int main(){ int n; scanf("%d", &am原创 2021-08-05 20:27:58 · 266 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-5 递归计算Ackermenn函数
题目要求:本题要求实现Ackermenn函数的计算,其函数定义如下:函数接口定义:int Ack( int m, int n );其中m和n是用户传入的非负整数。函数Ack返回Ackermenn函数的相应值。题目保证输入输出都在长整型范围内。裁判测试程序样例:#include <stdio.h>int Ack( int m, int n );int main(){ int m, n; scanf("%d %d", &m, &n);原创 2021-08-05 20:02:23 · 207 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-4 递归求简单交错幂级数的部分和
题目要求:本题要求实现一个函数,计算下列简单交错幂级数的部分和:f(x,n)=x−x ^2+x ^3−x ^4+⋯+(−1) ^n−1x ^n函数接口定义:double fn( double x, int n );其中题目保证传入的n是正整数,并且输入输出都在双精度范围内。函数fn应返回上述级数的部分和。建议尝试用递归实现。裁判测试程序样例:#include <stdio.h>double fn( double x, int n );int main(){ do原创 2021-08-05 19:46:35 · 895 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-3 递归实现指数函数
题目要求:本题要求实现一个计算x ^n(n≥1)的函数。函数接口定义:double calc_pow( double x, int n );函数calc_pow应返回x的n次幂的值。建议用递归实现。题目保证结果在双精度范围内。裁判测试程序样例:#include <stdio.h>double calc_pow( double x, int n );int main(){ double x; int n; scanf("%lf %d", &原创 2021-08-05 17:57:26 · 336 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-2 递归求阶乘和
题目要求:本题要求实现一个计算非负整数阶乘的简单函数,并利用该函数求 1!+2!+3!+…+n! 的值。函数接口定义:double fact( int n );double factsum( int n );函数fact应返回n的阶乘,建议用递归实现。函数factsum应返回 1!+2!+…+n! 的值。题目保证输入输出在双精度范围内。裁判测试程序样例:#include <stdio.h>double fact( int n );double factsum( int n原创 2021-08-05 17:48:27 · 275 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题10-1 判断满足条件的三位数
题目要求:本题要求实现一个函数,统计给定区间内的三位数中有两位数字相同的完全平方数(如144、676)的个数。函数接口定义:int search( int n );其中传入的参数int n是一个三位数的正整数(最高位数字非0)。函数search返回[101, n]区间内所有满足条件的数的个数。裁判测试程序样例:#include <stdio.h>#include <math.h>int search( int n );int main(){ int原创 2021-08-04 20:58:54 · 371 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 练习10-1 使用递归函数计算1到n之和
题目要求:本题要求实现一个用递归计算1+2+3+…+n的和的简单函数。函数接口定义:int sum( int n );该函数对于传入的正整数n返回1+2+3+…+n的和;若n不是正整数则返回0。题目保证输入输出在长整型范围内。建议尝试写成递归函数。裁判测试程序样例:#include <stdio.h>int sum( int n );int main(){ int n; scanf("%d", &n); printf ("%d\n", s原创 2021-08-04 19:40:05 · 255 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-6 按等级统计学生成绩
题目要求:本题要求实现一个根据学生成绩设置其等级,并统计不及格人数的简单函数。函数接口定义:int set_grade( struct student *p, int n );其中p是指向学生信息的结构体数组的指针,该结构体的定义为:struct student{ int num; char name[20]; int score; char grade;};n是数组元素个数。学号num、姓名name和成绩score均是已经存储好的。set_grade函数需原创 2021-08-03 19:17:24 · 340 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-5 通讯录排序
题目要求:输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。输入格式:输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。输出格式:按照年龄从大到小输出朋友的信息,格式同输出。输入样例1:3zhang 198504原创 2021-08-03 18:50:26 · 651 阅读 · 1 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-4 查找书籍
题目要求:给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。输入格式:输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。输出格式:在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。输入样例1:3Programming in C21.5Programming in VB18.5Programming in原创 2021-08-02 21:36:09 · 347 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-3 平面向量加法
题目要求:本题要求编写程序,计算两个二维平面向量的和向量。输入格式:输入在一行中按照“x1 y1 x2 y2 ”的格式给出两个二维平面向量v1=(x1,y1)和v2=(x2,y2)的分量。输出格式:在一行中按照(x, y)的格式输出和向量,坐标输出小数点后一位(注意不能输出−0.0)。输入样例1:3.5 -2.7 -13.9 8.7输出样例1:(-10.4, 6.0)代码:#include <stdio.h>#include <math.h>int原创 2021-08-02 20:44:26 · 272 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-2 计算两个复数之积
题目要求:本题要求实现一个计算复数之积的简单函数。函数接口定义:struct complex multiply(struct complex x, struct complex y);其中struct complex是复数结构体,其定义如下:struct complex{ int real; int imag;};裁判测试程序样例:#include <stdio.h>struct complex{ int real; int imag;}原创 2021-08-02 20:22:02 · 285 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题9-1 时间换算
题目要求:本题要求编写程序,以hh:mm:ss的格式输出某给定时间再过n秒后的时间值(超过23:59:59就从0点开始计时)。输入格式:输入在第一行中以hh:mm:ss的格式给出起始时间,第二行给出整秒数n(<60)。输出格式:输出在一行中给出hh:mm:ss格式的结果时间。输入样例1:11:59:4030输出样例1:12:00:10代码:#include <stdio.h>struct time{ int hour; int minute; int原创 2021-08-01 20:37:04 · 277 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-10 输出学生成绩
题目要求:本题要求编写程序,根据输入学生的成绩,统计并输出学生的平均成绩、最高成绩和最低成绩。建议使用动态内存分配来实现。输入格式:输入第一行首先给出一个正整数N,表示学生的个数。接下来一行给出N个学生的成绩,数字间以空格分隔。输出格式:按照以下格式输出:average = 平均成绩max = 最高成绩min = 最低成绩结果均保留两位小数。输入样例1:385 90 95输出样例1:average = 90.00max = 95.00min = 85.00代码:#i原创 2021-08-01 20:05:33 · 1396 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-9 分类统计各类字符个数
题目要求:本题要求实现一个函数,统计给定字符串中的大写字母、小写字母、空格、数字以及其它字符各有多少。函数接口定义:void StringCount( char *s );其中 char *s 是用户传入的字符串。函数StringCount须在一行内按照大写字母个数 小写字母个数 空格个数 数字个数 其它字符个数的格式输出。函数palindrome判断输入字符串char *s是否为回文。若是则返回true,否则返回false。裁判测试程序样例:#include <stdio.h&原创 2021-07-30 21:52:08 · 370 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-8 判断回文字符串
题目要求:本题要求编写函数,判断给定的一串字符是否为“回文”。所谓“回文”是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是回文。函数接口定义:bool palindrome( char *s );函数palindrome判断输入字符串char *s是否为回文。若是则返回true,否则返回false。裁判测试程序样例:#include <stdio.h>#include <string.h>#define MAXN 20typedef enum原创 2021-07-30 21:04:49 · 760 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-7 字符串排序
题目要求:本题要求编写程序,读入5个字符串,按由小到大的顺序输出。输入格式:输入为由空格分隔的5个非空字符串,每个字符串不包括空格、制表符、换行符等空白字符,长度小于80。输出格式:按照以下格式输出排序后的结果:After sorted:每行一个字符串输入样例1:red yellow blue green white输出样例1:After sorted:bluegreenredwhiteyellow代码:#include <stdio.h>#inclu原创 2021-07-30 21:02:12 · 434 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-6 删除字符
题目要求:本题要求实现一个删除字符串中的指定字符的简单函数。函数接口定义:void delchar( char *str, char c );其中char *str是传入的字符串,c是待删除的字符。函数delchar的功能是将字符串str中出现的所有c字符删除。裁判测试程序样例:#include <stdio.h>#define MAXN 20void delchar( char *str, char c );void ReadString( char s[] ); /*原创 2021-07-30 19:57:40 · 528 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-4 报数
题目要求:本题要求实现一个对数组进行循环右移的简单函数:一个数组a中存有n(>0)个整数,将每个整数循环向右移m(≥0)个位置,即将a中的数据由(a0a1⋯an−1)变换为(an−m⋯a n−1a0a1 ⋯an−m−1 )(最后m个数循环移至最前面的m个位置)。函数接口定义:int ArrayShift( int a[], int n, int m );其中a[]是用户传入的数组;n是数组的大小;m是右移的位数。函数ArrayShift须将循环右移后的数组仍然存在a[]中。裁判测试程序样原创 2021-07-28 17:35:32 · 687 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-3 数组循环右移
题目要求:本题要求实现一个对数组进行循环右移的简单函数:一个数组a中存有n(>0)个整数,将每个整数循环向右移m(≥0)个位置,即将a中的数据由(a0a1⋯an−1)变换为(an−m⋯a n−1a0a1 ⋯an−m−1 )(最后m个数循环移至最前面的m个位置)。函数接口定义:int ArrayShift( int a[], int n, int m );其中a[]是用户传入的数组;n是数组的大小;m是右移的位数。函数ArrayShift须将循环右移后的数组仍然存在a[]中。裁判测试程序样原创 2021-07-24 21:44:54 · 457 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-2 在数组中查找指定元素
题目要求:本题要求实现一个在数组中查找指定元素的简单函数。函数接口定义:int search( int list[], int n, int x );其中list[]是用户传入的数组;n(≥0)是list[]中元素的个数;x是待查找的元素。如果找到则函数search返回相应元素的最小下标(下标从0开始),否则返回−1。裁判测试程序样例:#include <stdio.h>#define MAXN 10int search( int list[], int n, int x原创 2021-07-24 19:47:18 · 497 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题8-1 拆分实数的整数与小数部分
题目要求:本题要求实现一个拆分实数的整数与小数部分的简单函数。函数接口定义:void splitfloat( float x, int *intpart, float *fracpart );其中x是被拆分的实数(0≤x<10000),*intpart和*fracpart分别是将实数x拆分出来的整数部分与小数部分。裁判测试程序样例:#include <stdio.h>void splitfloat( float x, int *intpart, float *fracpa原创 2021-07-24 19:28:40 · 678 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-8 字符串转换成十进制整数
题目要求:输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。输入格式:输入在一行中给出一个以#结束的非空字符串。输出格式:在一行中输出转换后的十进制数。题目保证输出在长整型范围内。输入样例1:+-P-xf4+-1!#输出样例1:-3905代码:#include <stdio.h>#include <ctype.原创 2021-07-16 23:37:55 · 1456 阅读 · 2 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-7 字符串替换
题目要求:本题要求编写程序,将给定字符串中的大写英文字母按以下对应规则替换:原字母 对应字母A ZB YC XD W… …X CY BZ A输入格式:输入在一行中给出一个不超过80个字符、并以回车结束的字符串。输出格式:输出在一行中给出替换完成后的字符串。输入样例1:Only the 11 CAPItaL LeTtERS are replaced.输出样例1:Lnly the 11 XZKRtaO OeGtVIH are replaced.代码:#include原创 2021-07-16 21:43:20 · 553 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-6 统计大写辅音字母
题目要求:英文辅音字母是除A、E、I、O、U以外的字母。本题要求编写程序,统计给定字符串中大写辅音字母的个数。输入格式:输入在一行中给出一个不超过80个字符、并以回车结束的字符串。输出格式:输出在一行中给出字符串中大写辅音字母的个数。输入样例1:HELLO World!输出样例1:4代码:#include <stdio.h>int main(){ int i, a[80], count = 0; while((a[i]=getchar())!='\n')原创 2021-07-16 21:25:34 · 297 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-5 找鞍点
题目要求:一个矩阵元素的“鞍点”是指该位置上的元素值在该行上最大、在该列上最小。本题要求编写程序,求一个给定的n阶方阵的鞍点。输入格式:输入第一行给出一个正整数n(1≤n≤6)。随后n行,每行给出n个整数,其间以空格分隔。输出格式:输出在一行中按照“行下标 列下标”(下标从0开始)的格式输出鞍点的位置。如果鞍点不存在,则输出“NONE”。题目保证给出的矩阵至多存在一个鞍点。输入样例1:41 7 4 14 8 3 61 6 1 20 7 8 9输出样例1:2 1输入样例2:原创 2021-07-16 21:04:14 · 528 阅读 · 3 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-4 求矩阵各行元素之和
题目要求:本题要求编写程序,求一个给定的m×n矩阵各行元素之和。输入格式:输入第一行给出两个正整数m和n(1≤m,n≤6)。随后m行,每行给出n个整数,其间以空格分隔。输出格式:每行输出对应矩阵行元素之和。输入样例1:3 26 31 -83 12输出样例1:9-715代码:#include <stdio.h>int main(){ int m, n, i, j, a[6][6], sum = 0; scanf("%d%d", &m, &原创 2021-07-16 18:02:16 · 765 阅读 · 0 评论 -
浙大版《C语言程序设计(第4版)》题目集 习题7-2 求一批整数中出现最多的个位数字
题目要求:给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。输入格式:输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。输出格式:在一行中按格式“M: n1 n2 …”输出,其中M是最大次数,n1、n2、……为出现次数最多的个位数字,按从小到大的顺序排列。数字间以空格分隔,但末尾不得有多余空格。输入样例1:31234 2345 34原创 2021-07-14 19:50:22 · 522 阅读 · 0 评论