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

推荐阅读
  • 本文介绍了GTK+中的GObject对象系统,该系统是基于GLib和C语言完成的面向对象的框架,提供了灵活、可扩展且易于映射到其他语言的特性。其中最重要的是GType,它是GLib运行时类型认证和管理系统的基础,通过注册和管理基本数据类型、用户定义对象和界面类型来实现对象的继承。文章详细解释了GObject系统中对象的三个部分:唯一的ID标识、类结构和实例结构。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 开发笔记:实验7的文件读写操作
    本文介绍了使用C++的ofstream和ifstream类进行文件读写操作的方法,包括创建文件、写入文件和读取文件的过程。同时还介绍了如何判断文件是否成功打开和关闭文件的方法。通过本文的学习,读者可以了解如何在C++中进行文件读写操作。 ... [详细]
  • 本文介绍了在Windows系统上使用C语言命令行参数启动程序并传递参数的方法,包括接收参数程序的代码和bat文件的编写方法,同时给出了程序运行的结果。 ... [详细]
  • C语言判断正整数能否被整除的程序
    本文介绍了使用C语言编写的判断正整数能否被整除的程序,包括输入一个三位正整数,判断是否能被3整除且至少包含数字3的方法。同时还介绍了使用qsort函数进行快速排序的算法。 ... [详细]
  • 本文详细介绍了GetModuleFileName函数的用法,该函数可以用于获取当前模块所在的路径,方便进行文件操作和读取配置信息。文章通过示例代码和详细的解释,帮助读者理解和使用该函数。同时,还提供了相关的API函数声明和说明。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • C语言注释工具及快捷键,删除C语言注释工具的实现思路
    本文介绍了C语言中注释的两种方式以及注释的作用,提供了删除C语言注释的工具实现思路,并分享了C语言中注释的快捷键操作方法。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • c语言\n不换行,c语言printf不换行
    本文目录一览:1、C语言不换行输入2、c语言的 ... [详细]
  • 本文介绍了一种划分和计数油田地块的方法。根据给定的条件,通过遍历和DFS算法,将符合条件的地块标记为不符合条件的地块,并进行计数。同时,还介绍了如何判断点是否在给定范围内的方法。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • Linux环境变量函数getenv、putenv、setenv和unsetenv详解
    本文详细解释了Linux中的环境变量函数getenv、putenv、setenv和unsetenv的用法和功能。通过使用这些函数,可以获取、设置和删除环境变量的值。同时给出了相应的函数原型、参数说明和返回值。通过示例代码演示了如何使用getenv函数获取环境变量的值,并打印出来。 ... [详细]
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社区 版权所有