《算法笔记》(胡凡)day3 入门模拟(2)

1、2、3 见day2

前三个常见算法见博客中day2的内容
连接如下
https://blog.csdn.net/weixin_44952817/article/details/108955825

4.日期处理问题

日期处理问题较为复杂,因为涉及到处理平闰年,以及由此产生的二月的天数问题,大小月问题。

1.日期差值

在这里插入图片描述
这个问题的解题思路为:
1.分解输入的八位数字,前四位为年份,第五和第六位是月份,第七第八位是日期。
2.小的日期的天数不断+1,超过月份最大日期后,月份+1,超过12月之后,年份+1,一直到两个日期相等,过程中记录天数+1的次数,从1开始累加就可以得到最终的结果。
重点包括:
1.判断年份是平还是闰,根据这个设置每月的天数(主要是二月)。可以借助二维数组实现。
2.分割数字,整除和取余的灵活运用,整除10的n次方(/)是从左侧起,保留n位,对10的n次方取余(%)是从右侧起保留n位。

#include<stdio.h>
int year(int x)//判断闰年还是平年 
{
	if((x % 4== 0 && x % 100!=0)||( x % 400 ) == 0 )
	{
		return 1;
	}
	else
	{
		return 0;
	}
}
int month[13][2]={{0,0},{31,31},{28,29},{31,31},{30,30},{31,31},{30,30},{31,31},
	{31,31},{30,30},{31,31},{30,30},{31,31}};//用二维数组表示平闰年 
int main()
{
	int a,b;
	int y1,y2,m1,m2,d1,d2;
	while(scanf("%d%d",&a,&b)!=EOF)
	{
		if(a>b)
		{
			int temp;
			temp=a;
			a=b;
			b=temp;
		}
		y1=a/10000;
		y2=b/10000;
		m1=a%10000/100;
		m2=b%10000/100;
		d1=a%100;
		d2=b%100;
		/*分别求年月日*/
		int d=1;//记录结果
		while(y1<y2||m1<m2||d1<d2)
		{
			d1++;
			if(d1==month[m1][year(y1)]+1)
			{
				m1++;
				d1=1;
			}
			if(m1==13)
			{
				y1++;
				m1=1;
			}
			d++;
		}
		printf("%d\n",d); 	
	} 
	return 0;
	
} 

5.进制转换问题

对于一个P进制的数字,如果要转换为Q进制,分为两步:
1.将P进制的数字x转换为十进制的数字y;
对于一个十进制的数字y=d1d2…dn,它可以写成这个形式:
在这里插入图片描述
同样的,P进制的数字也可以写成
在这里插入图片描述
而这个公式可以通过循环实现:

int y=0,product=1;//product在循环中会不断的乘P,得到 1,p,p^2.....
while(x!=0)
{
	y=y+(x%10)*product;//%10是为了获取最右侧一位的数字 
	x=x/10;//去掉最右侧位的数字 
	product=product * p;
 } 

2.将十进制数字y转换为Q进制的数字z
采用“除基数取余数”方法。
例如11转换为2进制数字:
11/2=5…1
5/2=2…1
2/2=1…0
1/2=0…1
结束
余数从后往前输出,即得到1011为11的二进制表示

 int z[40],num=0;//z用来保存Q进制的数字Y的每一位,num为位数
 do
 {
 	z[num++]=y%Q;
 	y=y/Q;
 } while(y!=0);//商不为0时候循环 

D进制的A+B

在这里插入图片描述

#include<stdio.h>
int main()
{
	int a,b,d;
	scanf("%d%d%d",&a,&b,&d);
	int e=a+b;
	int z[40],num=0;
	while(e!=0)
	{
		z[num++]=e%d;
		e=e/d;
	}
	for(int i=num-1;i>=0;i--)
	{
		printf("%d",z[i]);
	}
	return 0;	
} 

6. 字符串处理

1.回文串问题

在这里插入图片描述

#include<stdio.h>
#include<string.h>
int main()
{
	char str[255];
	gets(str);
	int len=strlen(str);
	int m;
	if(len%2==0)
	{
		int n=len/2;
		for(int i=0;i<n;i++)
		{
			if(str[i]!=str[len-1-i])
			{
				printf("NO\n");
				break;
			}
			if(i==n-1)
			{
				printf("YES\n");
			}
		}
	}
	else
	{
		int n=len/2+1;
		for(int i=0;i<n;i++)
		{
			if(str[i]!=str[len-1-i])
			{
				printf("NO\n");
				break;
			}
			if(i==n-1)
			{
				printf("YES\n");
			}
			
		}
		
	}
	return 0;
}

2.说反话

在这里插入图片描述
思路:
1.接收整个字符串后,解析字符串,用字符的二维数组把单词按行存放。(注意,每一行结束用\0);
2.倒序输出字符的二维数组即可;

#include<stdio.h>
#include<string.h>
int main()
{
	char str[90];
	char str0[90][90];
	gets(str);
	int len=strlen(str);
	int j=0;
	int h=0; 
	for(int i=0;i<len;i++)
	{
		
		if(str[i]!=' ')
		{
			str0[j][h]=str[i];
			h++;
		}
		else
		{
			str0[j][h]='\0';
			j++;
			h=0;
		}
	}
	for(int i=j;i>=0;i--)
	{
		int m=0;
		while(str0[i][m]!='\0')
		{
			printf("%c",str0[i][m]);
			m=m+1;	
		}
		printf(" ");
	}
	return 0; 
 } 
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 《算法笔记》是由胡凡编写的一本关于算法学习的教材,它最初以C/C++为主要编程语言。这本教材主要面向想要学习算法的初学者,以及希望进一步提升算法能力的人群。 《算法笔记》的内容广泛而且深入,涵盖了很多算法的基础知识和主要思想,如递归、排序、查找、图论、动态规划等。通过学习这本教材,读者可以掌握这些算法的基本原理和实现方法,提高解决实际问题的能力。 该教材有几个特点:首先,它提供了很多例子和习题,帮助读者巩固所学的知识;其次,它介绍了很多常用的数据结构,如数组、链表、栈、队列等,读者可以通过学习这些数据结构更好地理解和应用算法;最后,它还介绍了一些高级主题,如高级数据结构、算法优化等,这些内容对于进一步提升算法水平非常有帮助。 《算法笔记》是一本入门级的教材,因此在阅读时需要一些基本的编程知识和逻辑思维能力。该教材的语言简洁明快,适合作为学习参考书,同时也可以作为算法竞赛的辅助教材。 总而言之,《算法笔记》是一本很好的算法学习教材,它以C/C++为编程语言,全面介绍了算法的基本知识和常用方法,适合想要学习算法的初学者。无论是学术研究还是实际应用,阅读《算法笔记》都能提升算法能力,并为进一步学习和应用算法打下坚实的基础。 ### 回答2: 《算法笔记 胡凡 c/c 快速入门pdf》是一本介绍算法和C/C++编程语言的入门书籍。该书的作者是胡凡,它主要规划了算法的学习路径以及基本的C/C++编程语言。这本书适合初学者快速入门,对于想要系统学习算法和C/C++编程的人来说是一本不错的选择。 这本书的内容非常系统和全面。它以算法和数据结构为基础,包括基本排序、查找、图论等算法的介绍和实践,让读者能够快速掌握这些算法的原理和实现方法。同时,它还介绍了C/C++语言的基础知识和编程技巧,帮助读者理解和运用这些知识。 书中每章都有一些练习题,帮助读者巩固所学的知识。同时,每个章节末尾还提供了一些进阶的题目和参考答案,供读者深入学习和自我检测。这样的设计能够帮助读者更好地理解和掌握所学的内容。 总的来说,《算法笔记 胡凡 c/c 快速入门pdf》是一本很好的算法和C/C++入门书籍。它能够帮助读者快速了解算法和数据结构的基础知识,并学会使用C/C++语言进行编程。无论是对于想要入门算法和C/C++编程的初学者,还是已经有一定基础的读者,这本书都是一个很好的选择。 ### 回答3: 《算法笔记胡凡C/C++快速入门PDF》是一本很棒的入门算法书籍。这本书主要介绍了常用的数据结构与算法,并通过C/C++语言来实现这些算法。 首先,这本书非常适合算法初学者。它从基础的数据结构开始讲解,如数组、链表、栈和队列,然后逐渐引入更复杂的数据结构,如二叉树、图和堆。此外,书中还介绍了常用的排序和查找算法,如冒泡排序、快速排序、二分查找等。每个算法都配有具体的代码实现和详细的解释,帮助读者理解算法的原理和应用。 其次,这本书的学习资料丰富。书中提供了很多例题和习题,读者可以通过实践来巩固所学的知识。此外,书中还介绍了一些常见的算法优化技巧和设计思路,提供了一些高效解决问题的方法和思考方式。 最后,这本书的编写风格简明易懂。作者通过清晰的语言和简洁的代码,将复杂的算法问题简化为易于理解的部分。不论是对于算法初学者还是对于有一定编程基础的读者,这本书都是一本很好的学习资料。 总而言之,《算法笔记胡凡C/C++快速入门PDF》是一本很好的入门算法书籍。它适合初学者学习和理解常用的数据结构与算法,通过具体的代码实现和详细的解释帮助读者掌握算法的原理和应用。无论是编程初学者还是有一定基础的读者,都可以从这本书中获得丰富的知识和实践经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值