热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

谭浩强c语言课后习题笔记[第7章]

文章目录第七章函数7.3判断素数函数7.43阶矩阵的转置函数7.5字符串逆序7.7复制元音字符到另一字符串7.8输入4位数,输出的数字之间要求两两空格没写7.10找出字符串中最长的

文章目录

    • 第七章 函数
      • 7.3 判断素数函数
      • 7.4 3阶矩阵的转置函数
      • 7.5 字符串逆序
      • 7.7 复制元音字符到另一字符串
      • 7.8 输入4位数,输出的数字之间要求两两空格
      • 没写7.10 找出字符串中最长的单词
      • 7.11 冒泡排序
      • 7.12 牛顿迭代法求根
      • 7.13 递归求n阶勒让德多项式的值
      • 7.16 十六进制转换为十进制
      • 7.17 递归法实现整数转换为字符串
      • 7.18 给出年月日,计算是该年第几天

第七章 函数

7.3 判断素数函数

#include
int isprime(int n);
int main()
{
int n;

scanf("%d",&n);

if(isprime(n))
printf("Yes!This is a prime number");
else
printf("No!This is not prime number");

return 0;
}
int isprime(int n)
{
int i,flag=1;

for(i=2;i<n;i++)
{
if(n%i==0)
{
flag=0;
break;
}
}
return flag;
}

7.4 3阶矩阵的转置函数

#include
#define N 3
void transposition(int a[][3],int b[][3]);
int main()
{
int i,j,a[N][N],b[N][N];

//赋值
for(i=0;i<N;i++)
for(j=0;j<N;j++)
scanf("%d",&a[i][j]);
transposition(a,b);
printf("\ntransposition:\n");
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
printf("%d ",b[i][j]);
printf("\n");
}

return 0;
}
void transposition(int a[][N],int b[][N])
{
int i,j;

for(i=0;i<N;i++)
for(j=0;j<N;j++)
b[i][j]=a[j][i];
}

//n*m阶矩阵转置
#include
#define N 100
void transposition(int a[][N],int b[][N],int n,int m);
int main()
{
int i,j,a[N][N],b[N][N];
int n,m;
scanf("%d %d",&n,&m);

//赋值
for(i=0;i<n;i++)
for(j=0;j<m;j++)
scanf("%d",&a[i][j]);
transposition(a,b,n,m);
printf("\ntransposition:\n");
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
printf("%d ",b[i][j]);
printf("\n");
}

return 0;
}
void transposition(int a[][N],int b[][N],int n,int m)
{
int i,j;

for(i=0;i<n;i++)
for(j=0;j<m;j++)
b[j][i]=a[i][j];
}

7.5 字符串逆序

#include
#include
#define N 80
void strreversed(char str[]);
int main()
{
char str[N];
gets(str);

strreversed(str);
printf("逆序结果\n");
puts(str);


return 0;
}
void strreversed(char str[])
{
//不调用strlen求长度也可以用遍历求长度;
// int k=0;
// while(str[k]!='\0') k++;
// k=k-1;
int i,k=strlen(str)-1,temp;
for(i=0;i<k/2;i++)
{
temp=str[i];
str[i]=str[k-i];
str[k-i]=temp;
}
}

7.7 复制元音字符到另一字符串

#include
#define N 100
void aeiou_strcpy(char str1[],char str2[]);
int main()
{
char a[N],b[N];

//赋值
gets(a);
gets(b);

aeiou_strcpy(a,b);
//输出结果
printf("打印拷贝后的a:↓\n");
puts(a);

return 0;
}
void aeiou_strcpy(char str1[],char str2[]) //抽象为函数形式
{
int i,j;
for(i=0,j=0;str2[i]!='\0';i++)
{
if(str2[i]=='A'||str2[i]=='E'||str2[i]=='I'||str2[i]=='O'||str2[i]=='U')
{
str1[j]=str2[i];
j++;
}
if(str2[i]=='a'||str2[i]=='e'||str2[i]=='i'||str2[i]=='o'||str2[i]=='u')
{
str1[j]=str2[i];
j++;
}
}

str1[j]='\0';
}
/* 54654654654 ABECIDOWUaweyipou 打印拷贝后的a:↓ AEIOUaeiou */

7.8 输入4位数,输出的数字之间要求两两空格

#include
#define N 100
void blankprint(int n);
int main()
{
int number;

scanf("%d",&number);

blankprint(number);
return 0;
}
void blankprint(int n) //抽象为函数形式
{
int i,sum=0;
for(i=n;i>0;i/=10)
sum=sum*10+i%10;

printf("\n%d",sum%10);
for(i=sum/10;i>0;i/=10)
printf(" %d",i%10);

}
/* 1999 1 9 9 9 */

没写7.10 找出字符串中最长的单词

#include
#include
#define N 100
int searchlongword(char str[],int len);
int main()
{
char str[N];
int i,index;
//赋值
gets(str);

index=searchlongword(str,len);
printf("最长的单词为:\n");
for(i=index;str[i]!=' ';i++)
printf("%c",str[i]);

return 0;
}
int searchlongword(char str[],int len) //抽象为函数形式
{
int i,j,count=0;


int max=0;
for(i=1;i<len;i++)
if(strlen(str[max])<strlen(str[i]))
max=i;
return max;
}

/*输入单词数目,找到最长的单词(二维数组)*/
#include
#include
#define N 100
int searchlongword(char str[][N],int len);
int main()
{
char str[N][N];
int i,len;

scanf("%d",&len);
getchar();

for(i=0;i<len;i++)
gets(str[i]);

//返回最长单词的行下标
i=searchlongword(str,len);
printf("最长的单词为:\n");
puts(str[i]);

return 0;
}
int searchlongword(char str[][N],int len) //抽象为函数形式
{
int i,j,temp;

int max=0;
for(i=1;i<len;i++)
if(strlen(str[max])<strlen(str[i]))
max=i;
return max;
}
/* 4 blue yellow red green 最长的单词为: yellow */

7.11 冒泡排序

#include
#define N 100
void bubblesort(int a[],int len);
int main()
{
int i,a[N],len;

scanf("%d",&len);
for(i=0;i<len;i++)
scanf("%d",&a[i]);

bubblesort(a,len);

for(i=0;i<len;i++)
printf("%d ",a[i]);
return 0;
}
void bubblesort(int a[],int len) //抽象为函数形式
{
int i,j,temp;

for(i=0;i<len;i++)
for(j=0;j<len-1-i;j++)
{
if(a[j]>a[j+1]) //两两比较交换得到最后一个数为最大值,
{
temp=a[j];
a[j]=a[j+1];
a[j+1]=temp;
}
}

}

7.12 牛顿迭代法求根

#include
#include
double root(double a,double b,double c,double d);
int main()
{
double a,b,c,d;
scanf("%lf %lf %lf %lf",&a,&b,&c,&d);

printf("x = %10.7f",root(a,b,c,d));

return 0;
}
double root(double a,double b,double c,double d)
{
double x=1,x0,fx,fx0; //x在1附近
do{
x0=x;
fx=((a*x0+b)*x0+c)*x0+d;
fx0=(3*a*x0+2*b)*x0+c;
x=x0-fx/fx0;
}while(fabs(x-x0)>=1e-3);

return x;
}

7.13 递归求n阶勒让德多项式的值

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3zx13heK-1584544756260)(https://images.ptausercontent.com/48)]

#include
int Ack( int m, int n );
int main()
{
int m, n;
scanf("%d %d", &m, &n);
printf("%d\n", Ack(m, n));
return 0;
}
/* 你的代码将被嵌在这里 */
int Ack( int m, int n )
{
if(m==0)
return n+1;
else
{
if(n==0&&m>0)
return Ack(m-1,1);
else
return Ack(m-1,Ack(m,n-1));
}
}

7.16 十六进制转换为十进制

#include
#include
#define N 100
void HEXswitchDEC(char ch[]);
int main()
{
char ch[N];
gets(ch);

HEXswitchDEC(ch);
}
void HEXswitchDEC(char ch[])
{
int i,j,flag=1;
double sum=0,item;
while(ch[i]!='\0') i++;

for(j=i-1,i=0;j>=0;j--,i++)
{
if(ch[j]>='A'&&ch[j]<='F')
item=10.0+(double)(ch[j]-'A');
else if(ch[j]>='a'&&ch[j]<='f')
item=10.0+(double)(ch[j]-'a');
else if(ch[j]>='0'&&ch[j]<='9')
item=(double)(ch[j]-'0');
else
{
flag=0;
break;
}
sum=sum+item*pow(16,i);
}
if(flag)
printf("八进制 %s 转换为十进制 %.0f",ch,sum);
else
printf("输出有误");
}

/*16进制,8进制,2进制转换为十进制*/
#include
#include
#define N 100
void HEXswitchDEC(char ch[],int a);
int main()
{
int a;
char c,ch[N];
printf("输入当前进制:");
scanf("%d",&a);
getchar();
gets(ch);

HEXswitchDEC(ch,a);
return 0;
}
void HEXswitchDEC(char ch[],int a)
{
int i,j,flag=1;
double sum=0,item;
while(ch[i]!='\0') i++;

for(j=i-1,i=0;j>=0;j--,i++)
{
if(ch[j]>='A'&&ch[j]<='F')
item=10.0+(double)(ch[j]-'A');
else if(ch[j]>='a'&&ch[j]<='f')
item=10.0+(double)(ch[j]-'a');
else if(a<9&&ch[j]>='0'&&ch[j]<(char)(a+'0'))
item=(double)(ch[j]-'0');
else if(ch[j]>='0'&&ch[j]<'9')
item=(double)(ch[j]-'0');
else
flag=0;
sum=sum+item*pow(a,i);
}
if(flag)
printf("%d进制 %s 转换为十进制 %.0f",a,ch,sum);
else
printf("输出有误");
}

7.17 递归法实现整数转换为字符串

#include
#include
#define N 100
void fact(int n);
int main()
{
int n;
scanf("%d",&n);

printf("转换:\n");
if(n<0)
{
putchar('-');
n=-n;
}
fact(n);

return 0;
}
void fact(int n) //抽象为函数形式
{
if(n/10==0)
putchar((char)(n+'0'));
else
{
fact(n/10);
putchar((char)(n%10+'0'));
}

}

7.18 给出年月日,计算是该年第几天

#include
#include
int calday(int year,int month,int day);
int main()
{
int year,month,day;
scanf("%d/%d/%d",&year,&month,&day);

printf("%d/%02d/%02d 是 %d 的第 %d 天",year,month,day,year,calday(year,month,day));

return 0;
}
int calday(int year,int month,int day)
{
int i,sum=0,monthend[13]={ 1,31,28,31,30,31,30,31,31,30,31,30,31};

if((year%4==0&&year%100!=0)||year%400==0)
monthend[2]=29;

for(i=1;i<month;i++)
sum=sum+monthend[i];
sum+=day;

return sum;
}

推荐阅读
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • 题目Link题目学习link1题目学习link2题目学习link3%%%受益匪浅!-----&# ... [详细]
  • 本题涉及一棵由N个节点组成的树(共有N-1条边),初始时所有节点均为白色。题目要求处理两种操作:一是改变某个节点的颜色(从白变黑或从黑变白);二是查询从根节点到指定节点路径上的第一个黑色节点,若无则输出-1。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 题目描述:给定n个半开区间[a, b),要求使用两个互不重叠的记录器,求最多可以记录多少个区间。解决方案采用贪心算法,通过排序和遍历实现最优解。 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 本文详细介绍了如何构建一个高效的UI管理系统,集中处理UI页面的打开、关闭、层级管理和页面跳转等问题。通过UIManager统一管理外部切换逻辑,实现功能逻辑分散化和代码复用,支持多人协作开发。 ... [详细]
  • 本文探讨了 C++ 中普通数组和标准库类型 vector 的初始化方法。普通数组具有固定长度,而 vector 是一种可扩展的容器,允许动态调整大小。文章详细介绍了不同初始化方式及其应用场景,并提供了代码示例以加深理解。 ... [详细]
  • 本文详细探讨了VxWorks操作系统中双向链表和环形缓冲区的实现原理及使用方法,通过具体示例代码加深理解。 ... [详细]
  • 本教程涵盖OpenGL基础操作及直线光栅化技术,包括点的绘制、简单图形绘制、直线绘制以及DDA和中点画线算法。通过逐步实践,帮助读者掌握OpenGL的基本使用方法。 ... [详细]
author-avatar
跟-着感觉走
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有