例15   除法算式

问题描述

输入正整数n(2≤n≤68),按从小到大输出所有形如abcde/fghi=n的表达式。其中a~i为1~9的一个排列。

输入格式

每行为一个正整数n (n <= 1500),输入n=0结束。

输出格式

输出满足条件的所有形如abcde/fghi=n的表达式,每个表达式占一行,具体格式参见输出样例。

输入样例

4

20

62

0

输出样例

15768/3942=4

17568/4392=4

23184/5796=4

31824/7956=4

No Solution!

79546/1283=62

94736/1528=62

(1)编程思路。

本例需要先确定好穷举的思路。虽然题目说a~i为1~9的一个排列,但穷举1~9的所有排列显然没有必要。

可以穷举除数fghi,这是一个4位数,最小可为1234,最大可为9876,然后按fghi*n计算出abcde,最后判断这9个数字是否不相同。

为判断9个数字是否相同,可以定义一个数组flag[10],其中flag[i]的值表示数字i在算式中出现的次数,显然flag[1]~flag[9]的值全为1才满足要求。

另外,在穷举时进行适当优化。若计算出abcde小于12345,显然除数fghi太小,直接增大除数进行下次穷举;若计算出abcde大于98765,显然除数fghi太大,不再可能找到解,直接退出穷举循环。

(2)源程序。

#include

int main()

{

int n,x,y,i,flag[10],t;

while (scanf("%d",&n) && n!=0)

{

t=0;

for (y=1234;y<=9876;y++)

{

x=y*n;

if (x<12345) continue;

if (x>98765) break;

for (i=0;i<10;i++)

flag[i]=0;

flag[x/10000]++; flag[x%10000/1000]++;

flag[x%1000/100]++; flag[x%100/10]++;

flag[x%10]++;

flag[y/1000]++; flag[y%1000/100]++;

flag[y%100/10]++; flag[y%10]++;

for (i=1;i<10;i++)

if (flag[i]!=1) break;

if (i==10)

{

printf("%d/%d=%d\n",x,y,n);

t++;

}

}

if (t==0) printf("No Solution!\n");

}

return 0;

}

习题15

15-1  完美立方

问题描述

a3 +b3 + c3 = d3为完美立方等式。例如13 + 63 + 83 =93。编写一个程序,输出100以内的所有四元组(a, b, c, d),使得a3+b3+ c3 = d3,其中1≤a< b< c< d≤100。

输入格式

无输入

输出格式

100以内所有满足a3+b3+ c3 = d3的四元组(a, b, c, d),每行输出5组。

输入样例

无输入

输出样例

(  3,  4,  5,  6)  ( 1, 6,  8,  9)  ( 6,  8, 10, 12)  (  2, 12, 16, 18)  (  9, 12, 15, 18)

(  3,  10, 18, 19)  ( 7, 14, 17, 20)  ( 12, 16, 20, 24)  (  4, 17, 22, 25)  (  3, 18, 24, 27)

……

(1)编程思路。

因为要求100以内所有满足a3+b3+ c3 = d3的四元组(a, b, c, d),因此先定义一个数组int cube[101];,且cube[i]的值赋i3,以便于后面直接引用。

从d出发进行穷举,则穷举范围为

6≤d≤100

1≤a≤d-3

a+1≤b≤d-2

b+1≤c≤d-1

(2)源程序。

#include

int main()

{

int  i, a, b, c, d,cnt=0;

int cube[101];

for (i=1 ; i<=100; i++)

cube[i]=i*i*i;

for (d=6 ; d<=100; d++)

for (a=1; a

{

if (cube[d]

for (b=a+1 ; b

{

if (cube[d]

for (c=b+1; c

if (cube[d]==cube[a]+cube[b]+cube[c])

{

cnt++;

printf("(%3d,%3d,%3d,%3d)  ",a,b,c,d);

if (cnt%5==0) printf("\n");

}

}

}

return 0;

}

15-2  分数拆分

问题描述

输入正整数k,找到所有的正整数x≥y,使得1/k=1/x+1/y。

输入格式

输入包含多组测试数据,每组为一行,一个正整数k。

输出格式

对每组数据先输出解的个数,然后输出全部的解,没个解占一行。具体格式参见输出样例。

输入样例

2

12

输出样例

2

1/2=1/6+1/3

1/2=1/4+1/4

8

1/12=1/156+1/13

1/12=1/84+1/14

1/12=1/60+1/15

1/12=1/48+1/16

1/12=1/36+1/18

1/12=1/30+1/20

1/12=1/28+1/21

1/12=1/24+1/24

(1)编程思路。

乍一看穷举的范围好像无法确定,但由于x≥y, 有1/x≤1/y,

因此由1/k=1/x+1/y 可知  1/y =1/k-1/x≥1/k-1/y, 故 2/y≥1/k  即y≤2k。当然y≥k+1。这样只要在k+1~2k范围之内穷举y,然后根据y尝试计算出x即可。

(2)源程序1。

#include

int main()

{

int k;

while (scanf("%d",&k)!=EOF)

{

int x,y,cnt=0;

for (y=k+1;y<=2*k;y++)

{

if(k*y%(y-k)==0)

{

cnt++;

}

}

printf("%d\n",cnt);

for (y=k+1;y<=2*k;y++)

{

if(k*y%(y-k)==0)

{

x=k*y/(y-k);

printf("1/%d=1/%d+1/%d\n",k,x,y);

}

}

}

return 0;

}

(3)源程序2。

在源程序1中,穷举的循环进行了两次,一次用循环求出解的个数,另一次用循环输出各个解的情况。显然,可以在用循环求解的个数时用数组将求得的解的情况保存下来,这样就不用再次循环求解,直接输出用数组保存的解的情况即可。

#include

int main()

{

int k;

while (scanf("%d",&k)!=EOF)

{

int cnt=0;

int t;

int x[2*k],y[2*k];

for (t=k+1;t<=2*k;t++)

{

if(k*t%(t-k)==0)

{

x[cnt]=k*t/(t-k);

y[cnt]=t;

cnt++;

}

}

printf("%d\n",cnt);

for (t=0;t

{

printf("1/%d=1/%d+1/%d\n",k,x[t],y[t]);

}

}

return 0;

}

注意:在上面的源程序2中,x和y数组是定义的可变长数组,现在的C标准支持这样的用法。

15-3  一数三平方

问题描述

有一类六位数,不仅它本身是平方数,而且它的前三位与后三位也都是平方数,这类数称为“一数三平方数”。

输入格式

无输入

输出格式

输出所有的一数三平方数。每行输出一个一数三平方数,具体格式参见输出样例。

输入样例

无输入

输出样例

144400 : 12*12=144,20*20=400,380*380=144400

225625 : 15*15=225,25*25=625,475*475=225625

……

(1)编程思路。

如果程序对所有的六位数(100000~999999)进行穷举,判断这个六位数是否是一数三平方,显然比较麻烦。

由于一个“一数三平方”数,其前三位与后三位一定都是平方数,因此,可以先求出999以内的所有的平方数,最多只有32个(即0的平方~31的平方,32的平方1024超过了3位)。定义一个数组int a[32]来保存这32个平方数。

程序中对这32个平方数两两组成的六位数进行穷举判断,显然高三位必须为数组中a[10](即不小于10的平方100的数首位才不为0)之后的平方数。算法描述为:

for(i=10;i<=31;i++)

for(j=0;j<=31;j++)

{

c=1000*a[i] +a[j];              // a[i]作为高三位、a[j]作为低三位构成六位数

if( c是平方数)

输出相应信息并计数

}

(2)源程序。

#include

#include

int main()

{

int a[32],i,j;

long b,c,t;

for(i=0;i<=31;i++)              // 统计出从0到999之内的所有平方数

a[i]=i*i;

for(i=10;i<=31;i++)

{

b=1000*a[i];                                /*高三位数*/

for(j=0;j<=31;j++)

{

c=b+a[j];                              /*六位数*/

t=sqrt(c);                             /*六位数开方*/

if(c==t*t)                             /*判断六位数是否为平方数*/

{

printf("%d : %d*%d=%d,%d*%d=%d,%d*%d=%d\n",c,i,i,a[i],j,j,a[j],t,t,c);

}

}

}

return 0;

}

c语言15除以2得到8,C语言程序设计100例之(15):除法算式相关推荐

  1. c语言经典程序表白6,经典C语言程序设计100例(6)

    [程序61] 题目:打印出杨辉三角形(要求打印出10行如下图) 1.程序分析: 1 1 1 1 2 1 1 3 3 1 1 4 6 4 1 1 5 10 10 5 1 2.程序源代码: main() ...

  2. c语言学习100例(1-5)

    汉语版: 虽然说是100例,但是估计没那么多时间一一都写上去.所以能够发多少个实例,自己也不是很清楚.但是毫无疑问,自己会微笑的坚持下去的. 这些实例均是我自己写的,其中借鉴了一些算法,同时每个实例最 ...

  3. c语言黑匡程序,2020年新版C语言实用程序设计100例流程图.docx

    C 语言实用程序 100 例 第一篇 基础与提高 实例 1 利用库函数编写基本显示程序 实例 2 变量属性 实例 3 运算符与类型 实例 4 关于程序结构 实例 5 显示函数曲线图 实例 6 二分法选 ...

  4. 小学英语教学c语言,小学英语老师常用的课堂操练游戏100例

    原标题:小学英语老师常用的课堂操练游戏100例 如果您是一位热心于辅导孩子学习英语的家长,下边有些游戏也不妨用一用,不是仅限于教室哦~ 1.模仿秀 imitate show 游戏说明:教师带领学生一起 ...

  5. 简单c语言程序求和,C语言程序设计100例之(23):数列求和

    例23  数列求和 问题描述 已知某数列前两项为2和3,其后继项根据前面最后两项的乘积,按下列规则生成: ① 若乘积为一位数,则该乘积即为数列的后继项: ② 若乘积为二位数,则该乘积的十位上的数字和个 ...

  6. c语言 整数除以分数,2019年六年级数学上册 3.1分数除法(第1课时)分数除法的意义和整数除以分数练习题 新人教版 (I).doc...

    2019年六年级数学上册 3.1分数除法(第1课时)分数除法的意义和整数除以分数练习题 新人教版 (I).doc 下载提示(请认真阅读)1.请仔细阅读文档,确保文档完整性,对于不预览.不比对内容而直接 ...

  7. 黑马程序员——经典C语言程序设计100例

    1.数字排列 2.奖金分配问题 3.已知条件求解整数 4.输入日期判断第几天 5.输入整数进行排序 6.用*号显示字母C的图案 7.显示特殊图案 8.打印九九口诀 9.输出国际象棋棋盘 10.打印楼梯 ...

  8. 寻找最大公约数c语言,C语言程序设计100例之(10):最大公约数

    例10        最大公约数 问题描述 有三个正整数a,b,c(0 输入数据 第一行输入一个n,表示有n组测试数据,接下来的n行,每行输入两个正整数a,b. 输出格式 输出对应的c,每组测试数据占 ...

  9. 回旋矩形C语言,C语言程序设计100例之(27):回旋方阵

    例27        回旋方阵 问题描述 编写程序,生成从内到外是连续的自然数排列的回旋方阵.例如,当n=3和n=4时的回旋方阵如下图1所示. 图1  由内到外回旋方阵 输入格式 一个正整数n(1≤n ...

最新文章

  1. Java IO流读取文件
  2. 设计模式 | 适配器模式及典型应用
  3. Python进阶(上下文管理器与with语句)
  4. 如何理解android的函数,通过Android源码理解回调函数
  5. Java并发编程之FutureTask源码解析
  6. Web前端笔记-解决NicSroll使用后页面跳动(每次刷新或进入跳动一下然后正常)问题
  7. Python基础——6面向对象编程
  8. c语言全国计算机真题及答案,全国计算机C语言考试真题及答案.doc
  9. Python使用matplotlib设置pandas绘制的饼状图扇形标签
  10. 最新安徽省二c语言题型_2020年成人高考考试考前1个月最新最全备考攻略+资料,考生必看,建议收藏!...
  11. js如何在字符串里加变量
  12. java mojo是什么_java – 为什么Maven不能找到我的定制Mojo?
  13. 谷歌800多款开源字体
  14. AXURE RP 原型图绘制手册
  15. CSS不规则卡片-纯CSS制作优惠券样式-CSS实现锯齿样式
  16. 谷歌智能眼镜再掀数码浪潮
  17. 图像形状上下文特征ShapeContexts
  18. 计算机运维方向要考什么证,IT运维项目经理考的证
  19. 如何进阶优秀数据分析师行列?方法、技术与工具,缺一不可!
  20. 市场同类产品对比分析

热门文章

  1. STL之string篇
  2. meterpreter使用详解
  3. 【地图】计算不规则地图的外接矩形,以一个区(南京市玄武区)为例
  4. Android 监控手机应用使用情况
  5. 解密 | V神捐赠10个以太坊的AssangeDAO为何受到千万拥趸?
  6. UTC、GMT、时间戳之间的关系
  7. 前诺基亚MeeGo开发者揭示收款Jolla Sailfish智能手机
  8. 基于msp430G2553的低频方波频率、占空比、峰峰值测量函数
  9. 愚人节这天,我辞职了
  10. 什么?创业者别光想着做CEO,他首先应该是一名出色的销售(一)