[CCC 1996 01]Deficient, Perfect, and Abundant
CCC加拿大高中生信息学奥赛
其余来源
CODEVS[3312]——CCC 1996 01 Deficient, Perfect, and Abundant ——http://codevs.cn/problem/3312/
POJ[1928]——Perfection——http://poj.org/problem?id=1528
CODEVS描述——中文题目
题目描述 Description
读入一个正整数n,判断整数是完数,亏数还是盈数。
•如果它的约数的和等于它本身,那它便是一个完数(Perfect)(约数包含1,但不包含它本身)。
•如果它的约数的和小于它本身,那它便是一个亏数(Deficient)(约数包含1,但不包含它本身)。
•如果它的约数的和大于它本身,那它便是一个盈数(Abundant)(约数包含1,但不包含它本身)。
输入描述 Input Description
输入文件共两行,
第一行为一个正整数n,
第二行为n个正整数,中间用空格隔开。
输出描述 Output Description
输出为n行,分别为第1..n个数的类别。
完数:Perfect
亏数:Deficient
盈数:Abundant
样例输入 Sample Input
3
4 6 12
样例输出 Sample Output
4 is a deficient number.
6 is a perfect number.
12 is an abundant number.
数据范围及提示 Data Size & Hint
1<=n<=2^31-1
POJ描述(英文)
Description
Given a number, determine if it is perfect, abundant, or deficient.
Input
Output
Sample Input
15 28 6 56 60000 22 496 0
Sample Output
PERFECTION OUTPUT
15 DEFICIENT
28 PERFECT
6 PERFECT
56 ABUNDANT
60000 ABUNDANT
22 DEFICIENT
496 PERFECT
END OF OUTPUT
Source
思路
利用数论知识快速计算一个数的约数和,详见程序函数。
样例
CODEVS:
var t,x:longint; function ans(n:longint):longint;
var i:longint;
begin
ans:=;
for i:= to n do
begin
if (i*i=n) then
begin
ans:=ans+i;
break;
end;
if (i*i>n) then break;
if (n mod i=) then ans:=ans+i+n div i;
end;
end; procedure main;
var anss,n:longint;
begin
read(n);
anss:=ans(n)-n;
if anss<n then writeln(n,' is a deficient number.');
if anss=n then writeln(n,' is a perfect number.');
if anss>n then writeln(n,' is an abundant number.');
end; begin
readln(t);
for x:= to t do main;
end.
POJ:
var t,x,n:longint; function ans(n:longint):longint;
var i:longint;
begin
ans:=;
for i:= to n do
begin
if (i*i=n) then
begin
ans:=ans+i;
break;
end;
if (i*i>n) then break;
if (n mod i=) then ans:=ans+i+n div i;
end;
end; procedure main;
var anss,x,i:longint;s:ansistring;
begin
anss:=ans(n)-n;
str(n,s);
x:=length(s);
for i:= to -x do write(' ');
if anss<n then writeln(n,' DEFICIENT');
if anss=n then writeln(n,' PERFECT');
if anss>n then writeln(n,' ABUNDANT');
end; begin
writeln('PERFECTION OUTPUT');
while true do
begin
read(n);
if n= then
begin
writeln('END OF OUTPUT');
halt;
end;
main;
end;
end.
[CCC 1996 01]Deficient, Perfect, and Abundant的更多相关文章
- HDU1323_Perfection【水题】
		Perfection Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total ... 
- POJ 1528问题描述
		Description From the article Number Theory in the 1994 Microsoft Encarta: ``If a, b, c are integers ... 
- HDOJ 1323 Perfection(简单题)
		Problem Description From the article Number Theory in the 1994 Microsoft Encarta: "If a, b, c a ... 
- python开发学习-day10(select/poll/epoll回顾、redis、rabbitmq-pika)
		s12-20160319-day10 *:first-child { margin-top: 0 !important; } body>*:last-child { margin-bottom: ... 
- Python框架之Tornado(二)请求阶段
		概述 上图是tornado程序启动以及接收到客户端请求后的整个过程,对于整个过程可以分为两大部分: 启动程序阶段,又称为待请求阶段(上图1.2所有系列和3.0) 接收并处理客户端请求阶段(上图3系列) ... 
- python之协程与IO操作
		协程 协程,又称微线程,纤程.英文名Coroutine. 协程的概念很早就提出来了,但直到最近几年才在某些语言(如Lua)中得到广泛应用. 子程序,或者称为函数,在所有语言中都是层级调用,比如A调用B ... 
- 第二篇:白话tornado源码之待请求阶段
		上篇<白话tornado源码之一个脚本引发的血案>用上帝视角多整个框架做了一个概述,同时也看清了web框架的的本质,下面我们从tornado程序的起始来分析其源码. 概述 上图是torna ... 
- Python - 异步IO\数据库\队列\缓存
		协程 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程,协程一定是在单线程运行的. 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和 ... 
- sellect、poll、epoll
		http://www.cnblogs.com/alex3714/p/4372426.html select select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监视多 ... 
随机推荐
- demo_01 css3中的radius
			css属性:border-radius :border:边框:radius:弧度:所以这个属性的意思很明了. 下面实现一个小demo: <!doctype html> <html&g ... 
- centos用yum安装mysql-server
			1.安装:#yum -y install mysql-server 2.修改配置:#vi /etc/my.cnf 暂时修改一下编码(添加在密码下方添加): default-character-set ... 
- php查询ip地址来源归属地的脚本
			<?php header('Content-Type:text/html;charset=utf-8'); if($_GET['sub']){ $ip = $_GET['ip']; $msg = ... 
- eclipse import的项目报autowired cannot be resolved to a type的错误
			eclipse报autowired cannot be resolved to a type的错误,一般情况是依赖的JDK或者jar包有问题,检查build path可以排查文件,我今天遇到这个情况, ... 
- Bind Enum to ListControl
			当使用MVVM时,相信你和我一样经常有这样的需求: 在ViewModel里定义了一个Enum,它必然是对应UI上的一个ListControl作为不同选项. 有一种做法是使用Converter,将Enu ... 
- Oracle索引扫描
			Oracle索引扫描:先通过index查找到索引的值,并根据索引的值对应的rowid值(对于非唯一索引可能返回多个rowid值)直接从表中得到具体的数据.一个rowid唯一的表示一行数据,该行对应的数 ... 
- Kinetic使用注意点--canvas
			<virtual> new Canvas(width, height) 参数: width:canvas宽度 height:canvas高度 方法: applyShadow(shape, ... 
- CODEVS 1004四子连棋
			[题目描述 Description] 在一个4*4的棋盘上摆放了14颗棋子,其中有7颗白色棋子,7颗黑色棋子,有两个空白地带,任何一颗黑白棋子都可以向上下左右四个方向移动到相邻的空格,这叫行棋一步,黑 ... 
- linux 查看各服务状态chkconfig
			使用chkconfig 查看服务状态启动状态chkconfig --list 查看服务状态chkconfig --del <service name> 删除掉某项服务.在Fedora14中 ... 
- Html中如何让超链接a、图片img居中
			一.问题来源 修改博客页面时,突然想到 二.解决办法 2.1原来办法 在img和a中加入align="center",发现不行 2.2百度答案 <div align=&quo ... 
