解题思路:刚来这个网站不久,看了前辈们写的题解,感觉有点沉长,题目种说5位数和6位数的,并且从小到大;我直接按顺序遍历10000到1000000(不包括)之间的数,把么一个数就求其回文和给位数字之和来判断时候复合要求;判断回文:数组也可以做到,但是在本题种使用本人的做法可以简单的将判断回文和求个位数字之和一起方便求得;比如给出1221:1221%10=1 ->1221/10=122 -> 1*10+122%10=12 ->122/10=12 

->12*10+12%10=122 -> 12/10=1 -> 122*10+1%10=1221  得到1221与原来给出得相等;

在举个反例:123:123%10=3 -> 123/10=12 -> 3*10+12%10=32 -> 12/10=1 ->32*10+1%10=321;

                            123 != 321  故不是回文数;

求个位数字之和只用在求回文得时候 每次取余得到得数累加求和即可。

(刚开始使用这个,格式什么的还不会设置,望理解,谢谢)

注意事项:在判断回文的时候,记得用一个临时变量代替正在遍历的数,不然会影响遍历顺序,导致程序出错。

参考代码:

#include <stdio.h>
int main(void)
{
	int n, flag = 1;
	scanf("%d", &n);
	for(int i = 10000; i < 1000000; ++i)
	{
		int t = i, num = 0, sum = 0;
		while(t>0)
		{
			num = num*10 + t%10;
			sum += t%10;
			t /= 10;
		}
		if(num==i && sum==n)
		{
			flag = 0;
			printf("%d\n", i);
		}
	}
	if(flag)
	{
		printf("-1\n");
	}
	
	return 0;
}


点赞(42)
 

0.0分

86 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 42 条评论

浅滩 6年前 回复TA
我优化了你的代码
浅滩 6年前 回复TA
@下一站幸福 只用进行180次
浅滩 6年前 回复TA
@下一站幸福 #include<stdio.h> #include<stdlib.h> #include<string.h> int main() { 	int n,flag=0,i,j,k; 	scanf("%d",&n); 	for(i=1;i<=9;i++)//回文数是5位的情况  	{ 		for(j=0;j<=9;j++) 	    {	for(k=n-2*i-2*j;(k>=0&&k<10);) 			{ 				printf("%d%d%d%d%d\n",i,j,k,j,i); 					flag=1; 					break; 			} 		} 	} 	for(i=1;i<=9;i++)//回文数是6位的情况  	{ 		for(j=0;j<=9;j++) 		{ 			for(k=n-2*i-2*j;((k%2==0&&k/2<10)&&k/2>=0);) 			{ 					printf("%d%d%d%d%d%d\n",i,j,k/2,k/2,j,i); 					flag=1; 					break; 			} 		} 	} 	if(flag==0)	printf("-1\n");  }
浅滩 6年前 回复TA
@下一站幸福 我的算法时间效率更高
marker 6年前 回复TA
@marker 格式错误,希望大佬指出下
marker 6年前 回复TA
#include <stdio.h>
int turn (int num)
{
	int temp=0;
	while(num!=0)
	{
		temp=temp*10+num%10;
		num=num/10;

	}
	return temp;
}

int add (int num)
{
	int sum=0;
	while(num!=0)
	{
		sum=sum+num%10;
		num=num/10;

	}
	return sum;

}

int main()
{
    int i,n;
	int flag=0;
    scanf("%d",&n);
    for(i=10000;i<=999999;i++)
	{
		if(i==turn(i) && n==add(i) )
		{   
			flag=1;
			printf("%6d\n ",i);
		}
	}
	if(flag==0)
	{
		printf("-1\n");
	}

	return 0;
}
黑火 6年前 回复TA
@下一站幸福 可以  优秀啊
下一站幸福 6年前 回复TA
你那个算法须要循环90000次,我这个只需要1998次,论效率上我这个算法最快
下一站幸福 6年前 回复TA
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int main(){
	int n,is=0;
	scanf("%d",&n);
	for(int i=1;i<=9;i++){
		for(int j=0;j<=9;j++){
			for(int k=0;k<=9;k++){
				if(2*i+2*j+k==n){
					printf("%d%d%d%d%d\n",i,j,k,j,i);
					is=1;
				}
			}
		}
	}
	for(int i=1;i<=9;i++){
		for(int j=0;j<=9;j++){
			for(int k=0;k<=9;k++){
				if((i+j+k)*2==n){
					printf("%d%d%d%d%d%d\n",i,j,k,k,j,i);
					is=1;
					
				}
			}
		}
	}
	if(!is){
		printf("-1\n");
	}
	return 0;
}
咖啡 6年前 回复TA
@夏风 就是作为一个标志而已   判断是否有符合的要求的回文  没有就输出-1