热门标签 | 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;
}

推荐阅读
  • HDU 2537 键盘输入处理
    题目描述了一个名叫Pirates的男孩想要开发一款键盘输入软件,遇到了大小写字母判断的问题。本文提供了该问题的解决方案及实现方法。 ... [详细]
  • 本文档旨在提供C语言的基础知识概述,涵盖常量、变量、数据类型、控制结构及函数定义等内容。特别强调了常量的不同类型及其在程序中的应用,以及如何正确声明和使用函数。 ... [详细]
  • 本文详细探讨了select和epoll两种I/O多路复用技术的内部实现原理,分析了它们在处理大量文件描述符时的性能差异,并通过具体示例代码展示了select的工作流程。 ... [详细]
  • 本文详细介绍了跨站脚本攻击(XSS)的基本概念、工作原理,并通过实际案例演示如何构建XSS漏洞的测试环境,以及探讨了XSS攻击的不同形式和防御策略。 ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 本文详细介绍了在PHP中如何获取和处理HTTP头部信息,包括通过cURL获取请求头信息、使用header函数发送响应头以及获取客户端HTTP头部的方法。同时,还探讨了PHP中$_SERVER变量的使用,以获取客户端和服务器的相关信息。 ... [详细]
  • 题面:P3178[HAOI2015]树上操作好像其他人都嫌这道题太容易了懒得讲,好吧那我讲。题解:第一个操作和第二个操作本质上是一样的&# ... [详细]
  • Java高级工程师学习路径及面试准备指南
    本文基于一位朋友的PDF面试经验整理,涵盖了Java高级工程师所需掌握的核心知识点,包括数据结构与算法、计算机网络、数据库、操作系统等多个方面,并提供了详细的参考资料和学习建议。 ... [详细]
  • 本文详细探讨了 Android Service 组件中 onStartCommand 方法的四种不同返回值及其应用场景。Service 可以在后台执行长时间的操作,无需提供用户界面,支持通过启动和绑定两种方式创建。 ... [详细]
  • 汇编语言:编程世界的始祖,连C语言都敬畏三分!
    当C语言还在萌芽阶段时,它首次接触到了汇编语言,并对其简洁性感到震惊。尽管汇编语言的指令极其简单,但它却是所有现代编程语言的基础,其重要性不言而喻。 ... [详细]
  • 本文详细介绍了Socket在Linux内核中的实现机制,包括基本的Socket结构、协议操作集以及不同协议下的具体实现。通过这些内容,读者可以更好地理解Socket的工作原理。 ... [详细]
  • 本题旨在通过实现矩阵加法,加深对多维数组的理解。题目要求读取两个 n×m 的矩阵 A 和 B,并计算它们的和。 ... [详细]
  • UVa 11683: 激光雕刻技术解析
    自1958年发明以来,激光技术已在众多领域得到广泛应用,包括电子设备、医疗手术工具、武器等。本文将探讨如何使用激光技术进行材料雕刻,并通过编程解决一个具体的激光雕刻问题。 ... [详细]
  • 本文由公众号【数智物语】(ID: decision_engine)发布,关注获取更多干货。文章探讨了从数据收集到清洗、建模及可视化的全过程,介绍了41款实用工具,旨在帮助数据科学家和分析师提升工作效率。 ... [详细]
  • STM32代码编写STM32端不需要写关于连接MQTT服务器的代码,连接的工作交给ESP8266来做,STM32只需要通过串口接收和发送数据,间接的与服务器交互。串口三配置串口一已 ... [详细]
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社区 版权所有