基于visual Studio2013解决C语言竞赛题之0415特殊对数





基于visual Studio2013解决C语言竞赛题之0415特殊对数

题目

基于visual Studio2013解决C语言竞赛题之0415特殊对数

解决代码及点评

这道题也是锻炼for循环,在for循环中遍历所有可能的数,然后再判断该数是不是有这样的性质



/************************************************************************/
/*
15.两位数13和62具有很有趣的性质:把它们个位数字和十位数字对调,其乘积不变,即13*62=31*26。
编程序求共有多少对这种性质的两位数(个位与十位相同的不在此列,如11、22,重复出现的不在此列,如 13*62与62*13).基础10分。
*/
/************************************************************************/
#include <stdio.h>
#include <stdlib.h>

// 这个函数返回位数相反的数,比如num=62,经过这个函数转化成26
int f4151(int num)
{
return (num%10)*10+num/10;
}
bool f4152(int num1,int num2)
{
        // 首先判断是不是个位数和十位数相同
	if (num1/10==num1%10&&num2/10==num2%10)
return false;
	// 判断是不是有对数性质
if (num1*num2==f4151(num1)*f4151(num2))
{
return true;
}
else
return false;
}
void main()
{ int num=0;
for (int i=10;i<100;i++) // 遍历二位数
{
for (int j=i;j<100;j++) // 与它后续的每个二位数做一次判断
{
if (f4152(i,j)) // 如果这两个二位数有对数性质
{
printf("%5d,%5d\n",i,j); // 打印在屏幕上
num++;
} }
}
printf("共有%d对",num);
system("pause");
}

代码下载及其运行

代码下载链接:

http://download.csdn.net/detail/yincheng01/6640933

解压密码为c.itcast.cn

下载解压后用VS2013打开工程文件

点击 “本地Windows调试器” 执行

基于visual Studio2013解决C语言竞赛题之0415特殊对数

程序运行结果

基于visual Studio2013解决C语言竞赛题之0415特殊对数



上一篇:一键解决ScrollView嵌套ListView仅仅显示一行的问题


下一篇:groovy test