编写一个程序,输出各位数之和为9,且能被5整除的五位数的个数

御雪风尘 2012-11-13 10:42:19
编写一个程序,输出各位数之和为9,且能被5整除的五位数的个数
...全文
1628 8 打赏 收藏 转发到动态 举报
写回复
用AI写文章
8 条回复
切换为时间正序
请发表友善的回复…
发表回复
Alexander 2012-11-13
  • 打赏
  • 举报
回复
这题出的…… 用数学解法效率能提到很高: 各位数字之和为99的倍数(各位数字之和为9的倍数) 再加上能被5整除(5的倍数)这一条件,因此可以在45的倍数中进行筛选:

#include<stdio.h>

int main()
{
	int count=0,sum;
	long num,t;

	for(num=10035;num<100000L;num+=45)
	{
		sum=0,t=num;

		while(t)
			sum+=t%10,t/=10;

		if(sum==9)
			count++;
	}

	printf("Count:%d\n",count);

	return(0);
}
PS:如果LZ这是作业贴请慎用,非常规解法。如果碰到某些古板的老师估计会判错……
azzbcc 2012-11-13
  • 打赏
  • 举报
回复
#include <stdio.h>
void main()
{
	int n;
	int j;
	int Sum = 0;
	
	for (n = 10000;n < 100000;n += 5)
	{
		j = n;	Sum = 0;
		while (j)
		{
			Sum += j % 10;
			if (Sum > 9)
				break;
			j /= 10;
		}
		if (9 == Sum)
			printf("%d\t", n);
	}
	printf("\n");
}
breakfisher 2012-11-13
  • 打赏
  • 举报
回复
int main(void) { int num = 0 ; long i = 0; for(i = 10000; i<= 90000; i= i+5) { if(((i/10000) + (i/1000)%10 + (i/100)%10 + (i/10)%10 + (i%10)) == 9) num +=1; } printf("num: %d\n", num); }
御雪风尘 2012-11-13
  • 打赏
  • 举报
回复
引用 1 楼 anhuizhuanjiao 的回复:
刚帮你解决了一题,你这是老师布的作业吧
不是的。自己写了,感觉有的不太完美,毕竟考试写的有质量的,肯定得分高,所以看看人家怎么写的,对比下!请问您有扣扣什么的联系方式么
御雪风尘 2012-11-13
  • 打赏
  • 举报
回复
自己写了,感觉有的不太完美,毕竟考试写的有质量的,肯定得分高,所以看看人家怎么写的,对比下!请问您有扣扣什么的联系方式么
转角天边 2012-11-13
  • 打赏
  • 举报
回复
引用 2 楼 guyuhan 的回复:
不是,是入学考试的题目,没有正确答案,所以到这上面来找找了,因为自己写的不太好,上来看看有没有比较完善的代码!
都是些简单的题目,自己动手写写
御雪风尘 2012-11-13
  • 打赏
  • 举报
回复
不是,是入学考试的题目,没有正确答案,所以到这上面来找找了,因为自己写的不太好,上来看看有没有比较完善的代码!
转角天边 2012-11-13
  • 打赏
  • 举报
回复
刚帮你解决了一题,你这是老师布的作业吧
【课程简介】本课程是《Armv8/Armv9架构从入门到精通 第二期》中的第四章。建议购买大课程。本课程以为armv8-aarch64、armv9为基准,不涉及armv7及其以前的版本,也不涉及aarch32。本课程包含但不限于以下内容MMU的基础学习:啥是MMU?工作原理?MMU和cache之间的关系?及其怎样相互影响的?哪些是MMU硬件自动的行为?哪些是软件可配置的行为?地址空间基础:啥是虚拟地址空间?啥是物理地址空间?啥时memory-map? 代码程序中的虚拟地址空间是怎样的?arm core硬件决定的物理地址空间是怎样的?SOC memory-map时的地址空间是怎样的?具体的外设又是怎样的地址空间?Translation Regime:系统里有多少个MMU?系统里有多少个Translation Regime?他们之间的关系是怎样的?页表翻译:MMU是怎样翻译的?页表有几级?这些信息是怎么告诉MMU的,MMU又是怎样工作的,软件又需要怎样设计?stage1和stage2的区别和使用?Descriptor:啥是Descriptor、页表项、entry、条目、页表条目? Descriptor的格式是怎样的?每一个属性位是怎样的?MMU除了完成地址转换,属性权限的控制/cache的缓存策略是怎样配置的?optee中使用MMU的示例MMU深度思考篇:开启MMU瞬间可能出现的问题以及多种常用的解决方案。注意这里提到的是多种方案,绝大多人只知道第一种,除此之外还有没有其它的设计方式? MMU关闭时cache的缓存策略会怎样?【思考】01、一个大系统中有多少个MMU ?02、一个ARM Core中有多少个Translation regime?03、EL1&0 Translation regime Stage2、EL2 Translation regime stage1、EL2&0 Translation regime stage1 这三者的区别是什么?04、TTBR1_EL2寄存器有啥特殊性,这个寄存器是给谁使用的?05、有没有TTBR1_EL3寄存器?为什么?06、什么是memory-map? 一个ARM的系统中,有几套物理地址空间?07、页表到底有几级? 页表最少可以有几级?页表最多可以有几级?08、页表有多大? 页表存放在哪里?页表由谁来管理?09、页表是否能放在cache中?10、什么是Translation Table walk? 什么是TLB?11、请简述页表查询的过程?12、在一个大系统中,物理地址是多少位的? 物理地址是多少位指的是什么?虚拟地址又是多少位的? 物理地址的位和虚拟地址的位都是由谁来决定的?13、请说明entry、descriptor、页表项、条目 这个四个词汇的由来?14、TCR中有缓存属性和共享属性、页表的entry中也有缓存属性和共享属性,这俩有什么区别?15、请简述TTBR0和TTBR1的概念和意义?16、请简述cacheability和shareability属性的含义?17、stage1和stage2有何区别?18、stage1和stage2的descriptor中,有很多重复的属性,当两者属性有冲突了怎么办?19、L1、L2、L2的descriptor中也有部分相同的属性,重复时怎么办?20、Descriptor的格式有哪几种?21、Descriptor的类型有哪几种?22、简述您所观察到的系统软件中(操作系统或hypervisor)的shareability和cacheability一般都是怎样配置的?23、开启一个MMU的步骤是怎样的?24、啥是flat map? 啥是full level table?25、页表中的AF属性位、DBM属性位分别是干啥的?26、页表中的nG属性位是干啥的?27、页表中的Contiguous属性位是干啥的?28、在开启MMU的瞬间会考虑哪些事情?【课程目录】当前21节课,6.8小时

69,371

社区成员

发帖
与我相关
我的任务
社区描述
C语言相关问题讨论
社区管理员
  • C语言
  • 花神庙码农
  • 架构师李肯
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧