『每日一题 2012-03-25』巧填数字

简介: <p>问题描述:</p> <p><img src="http://my.csdn.net/uploads/201203/25/1332666872_4030.jpg" alt=""></p> <p></p> <p style="background:white"><strong>*问题分析与算法设计</strong><br> 问题本身并不复杂,可以对乘式中的每一位使用穷举法,最终可

问题描述:

*问题分析与算法设计
问题本身并不复杂,可以对乘式中的每一位使用穷举法,最终可以得到结果。本题的关键在于怎样有效的判断每个部分积的每一位是否满足题意,这一问题处理不好,编写的程序会很长。程序实现中采用了一个判断函数,通过传入函数的标志字符串对所有的数进行统一的判断处理。



#include<stdio.h>
void print(long a,long b,long s1,long s2,long s3);
int jud(long q,char *pflag);
int main()
{
	long i,j,k,l,m,n,term,t1,t2,t3;
	int flag;
	for(i=0;i<=4;++i) /*被乘数的第一位*/
		for(j=5;j<=9;++j) /*被乘数的第二位*/
			for(k=0;k<=4;++k) /*被乘数的第三位*/
			{
				term=100*i+10*j+k; /*被乘数*/
				for(flag=0,n=0;n<4&&!flag;) /*乘数的第一位*/
					flag=jud((t3=++n*100*term)/100,"001"); /*判断第三个部分积*/
				if(flag)
				{
					for(flag=0,m=0;m<4&&!flag;) /*乘数的第二位*/
						flag=jud((t2=++m*10*term)/10,"1100"); /*判断第二个部分积*/
					if(flag)
					{
						for(flag=0,l=5;l<9&&!flag;) /*乘数的第三位*/
							flag=jud(t1=++l*term,"0000"); /*判断第一个部分积*/
						if(flag&&jud(t1+t2+t3,"00101")) /*判断乘式的积*/
							print(term,n*100+m*10+l,t1,t2,t3);
					}
				}
			}
}
void print(long a,long b,long s1,long s2,long s3) /*打印结果*/ 
{
	printf("\n %ld\n",a);
	printf("*) %ld\n",b);
	printf("………………….\n");
	printf(" %ld\n %ld\n %ld\n",s1,s2/10,s3/100);
	printf("………………….\n");
	printf(" %ld\n",a*b);
}
int jud(long q,char *pflag) /*判断一个数的每一位是否满足要求的判断函数*/
/*q:需要判断的数。pflag:标志字符串,A用1表示,Z用0表示。标志串排列顺序:个十百…*/
{
	while(q!=0&&*pflag!=NULL) /*循环判断对应位的取值范围是否正确*/
		if(*pflag-'0'!=(q%10>=5?1:0)) /*标志位与对应的位不符,返回0*/
			return 0;
		else 
		{
			q/=10;++pflag; /*若相符则取下一位进行判断*/
		}
		if(q==0&&*pflag==NULL) /*q的位数与标志字符串的长度相同时,返回1*/
			return 1;
		else return 0;
}


目录
相关文章
【力扣每日一题】1365. 有多少小于当前数字的数字
【力扣每日一题】1365. 有多少小于当前数字的数字
|
5月前
|
存储 容器
【LeetCode刷题】只出现一次的数字(Ⅰ、Ⅱ、Ⅲ)
【LeetCode刷题】只出现一次的数字(Ⅰ、Ⅱ、Ⅲ)
|
6月前
每日一题——只出现一次的数字(II)
每日一题——只出现一次的数字(II)
每日一题——只出现一次的数字(II)
|
6月前
每日一题——只出现一次的数字
每日一题——只出现一次的数字
|
6月前
每日一题——只出现一次的数字(III)
每日一题——只出现一次的数字(III)
|
6月前
|
Java
每日一题《剑指offer》数组篇之和为S的两个数字
每日一题《剑指offer》数组篇之和为S的两个数字
43 0
每日一题《剑指offer》数组篇之和为S的两个数字
|
Java Python
leetcode每日一题.136:只出现一次的数字
leetcode每日一题.136:只出现一次的数字
56 0
|
存储
剑指offer 63. 和为S的两个数字
剑指offer 63. 和为S的两个数字
77 0
|
算法 C++ Python
每日算法系列【LeetCode 面试题 17.05】字母与数字
每日算法系列【LeetCode 面试题 17.05】字母与数字
LeetCode每日一题——902. 最大为 N 的数字组合
给定一个按 非递减顺序 排列的数字数组 digits 。你可以用任意次数 digits[i] 来写的数字。例如,如果 digits = [‘1’,‘3’,‘5’],我们可以写数字,如 ‘13’, ‘551’, 和 ‘1351315’。
96 0
LeetCode每日一题——902. 最大为 N 的数字组合