hdoj上一道有意思的题目,题目:

人见人爱a+b

敲的也蛮快的,大概十分钟左右就AC了。代码如下:

人见人爱a+b

#include<stdio.h>
int main()
{
int n,i,j,a1,a2,a3,b1,b2,b3,c1=0,c2=0,c3=0;//c1记录小时,c2记录分钟,c3记录秒;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
scanf("%d%d%d%d%d%d",&a1,&a2,&a3,&b1,&b2,&b3);
c3=a3+b3;
if(c3>=60)
{
c3=c3-60;
c2++;//分钟+1;
}
c2=c2+a2+b2;
if(c2>=60)
{
c2=c2-60;
c1++;//小时+1;
}
c1=c1+a1+b1;
printf("%d %d %d\n",c1,c2,c3);
c1=0;
c2=0;
c3=0;
}
return 0;
}

这题蛮有意思的,与往常的a+b题目不同,这里的a和b有一定的范围,它和时间计数的小时分钟秒类似,其中的分钟和秒的具体范围是0-60,于是相加以后就要判断有没有超出范围,有的话小时+1或者分钟+1。

回顾之前的面向对象程序设计课第二次作业,其题目也是不走寻常路,我在之前的博客也记录了它:程序设计第二次作业

这里来说说A+B*C和A+B/C的情况。

一、A+B*C

要求:输入均为整数,数值范围在(-1000000,1000000)之间。

代码如下:

#include <stdio.h>
int main()
{
int a, b,c,n;
scanf("%d %d %d",&a,&b,&c);
n=a+b*c;
if(n<0)
{
printf("-");//输出“-”号
n=-n;//取其绝对值
}
if(n<1000) printf("%d\n",n );
else if(n<1000000) printf("%d,%03d\n",n/1000,n%1000 );
else printf("%d,%03d,%03d\n",n/1000000,n%1000000/1000,n%1000 );//判断n的范围,用0补充位数
return 0;
}

A+B*C的做法与第二次作业的做法类似,用n来记录a+b*c的值,首先取其绝对值,如果是负数输出-号;再进行范围判断,通过%03d来补充位数。

二、A+B/C

要求:输入均为整数,数值范围在(-1000000,1000000)之间。保留两位小数。

代码如下:

#include<stdio.h>
int main()
{
int a,b,c,intn=0,intp=0;
double dout=0,doum=0;
scanf("%d%d%d",&a,&b,&c); intn=a+b*1.0/c;//n is int; mistake: b*1.0/c;
dout=a+b*1.0/c;//t is double; mistake: b*1.0/c;
doum=dout-intn;//doum : decimal
intp=doum*100;//intp : (int)decimal*100 if(intp<0)intp=-intp;// |intp|; if(intn<0)
{
printf("-");
intn=-intn; }
if(intn<1000) printf("%d",intn );
else if(intn<1000000) printf("%d,%03d",intn/1000,intn%1000 );
else printf("%d,%03d,%03d",intn/1000000,intn%1000000/1000,intn%1000 ); printf(".%02d",intp);//print the part of decimal return 0;
}
//-10 1 3
//-10 1 4
//-1000000 1 3
//1000000 1 4
//-1000 9 1

要求二相对要求一和之前的题目来说更难一些,我简单的阐述一下我的思路:

我定义整形变量intn和intp,intn来存储a+b/c的整数部分,intp来存储a+b/c的小数*100,也就是说我输出的时候,整数部分交由之前的方法处理,输出整数部分以后输出.和intp的绝对值。

取小数部分的做法:我先用一个int变量intn存储a+b/c的值,再用double类型的变量dout存储a+b/c的值,用两个值作差来得到小数部分,用double类型的doum来存储,最后intp把doum*100存储(相当于小数点后两位的数字)。

还有一个注意点是,最后我输出的格式:printf(".%02d",intp);用0补充位数。

遇到的问题:

在之前的代码里,我在给intn赋值的语句是:intn=a+b/c,这这导致b/c的计算结果是0,而不是我想要的0.33。

改进:intn=a+b*1.0/c

通过这一类型的题目,让我巩固了一些遗漏的知识点。a+b看似很简单,但是其中的题目还是隐藏着“杀机”。

                                                                                                             2016/2/26

hdoj上的一题和程序设计第二次作业的拓展-人见人爱a+b的更多相关文章

  1. 程序设计第二次作业<1>

    面向对象程序设计第二次作业<1> Github 链接:https://github.com/Wasdns/object-oriented 题目: <1>第一次尝试 我立马认识到 ...

  2. C语言程序设计第二次作业--顺序结构

    C语言程序设计第二次作业--顺序结构 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 #include <stido ...

  3. 面向对象程序设计 第二次作业<1>

    Github链接:https://github.com/zora02/object-oriented/tree/master/1001.A%2BB%20Format%20(20) 一.解题 题目 解题 ...

  4. C语言程序设计第二次作业——顺序结构

    (一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. 错误信息1: 错误原因:i和d位置错误 改正方法:i和d位置互换 错误信息2: 错误原因:\n后缺了一个" 改正方法:\n后加一个 ...

  5. C语言程序设计第二次作业—————顺序结构改

    1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 #include <stido.h> int mian() { ...

  6. C语言程序设计第二次作业1

    (一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 include int mian() { printf(&q ...

  7. C语言程序设计第二次作业0

    (一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 include int mian() { printf(&q ...

  8. C语言程序设计第二次作业—————顺序结构

    (一)改错题 1.输出带框文字:在屏幕上输出以下3行信息. ************* Welcome ************* 源程序 include int mian() { printf(&q ...

  9. C语言程序设计第二次作业

    一.学习内容 掌握关系运算符.逻辑运算符.条件运算符 掌握常用数学函数的用法 if语句(单分支,双分支和多分支) 用switch语句实现多分支 理解多个if语句,if...else if... 和if ...

随机推荐

  1. SQL Server 镜像证书过期处理

    转自:https://www.cnblogs.com/trams/archive/2012/01/13/2321637.html SQL Server 镜像证书过期处理 今天镜像中的主服务器进行维护重 ...

  2. MySQL 5.7怎么爬出暂时表空间的坑

    版权声明:本文为博主原创文章.未经博主同意不得转载. https://blog.csdn.net/n88Lpo/article/details/78126267 导读 怎样确认暂时表是由哪个用户连接创 ...

  3. Vue.js - 概述

    概述 Vue.js(读音 /vjuː/, 类似于 view)是一个构建数据驱动的 web 界面的库.Vue.js 的目标是通过尽可能简单的 API 实现响应的数据绑定和组合的视图组件. Vue.js ...

  4. plsql的sql窗口中文模糊查询没有作用

    环境变量新增: NLS_LANG = AMERICAN_AMERICA.AL32UTF8

  5. (转)How to Use Elasticsearch, Logstash, and Kibana to Manage MySQL Logs

    A comprehensive log management and analysis strategy is vital, enabling organizations to understand ...

  6. POJ:3083 Children of the Candy Corn(bfs+dfs)

    http://poj.org/problem?id=3083 Description The cornfield maze is a popular Halloween treat. Visitors ...

  7. libSVM简介及核函数模型选择

    1. libSVM简介 训练模型的结构体 struct svm_problem //储存参加计算的所有样本 { int l; //记录样本总数 double *y; //指向样本类别的组数 struc ...

  8. shell基础:1.0概述

    解释型.不用编译. 主要有两个工能:1.命令解释器 2.编程

  9. 文件操作(CRT、C++、WIN API、MFC)

    一.使用CRT函数文件操作 二.使用标准C++库 std::fstream std::string 1)std::string对象内部存储了一个C的字符串,以'\0'结尾的. 2)std::strin ...

  10. rpgmakermv插件(1)screenfull.js与Fullscreen.js

    本文分析游戏的全屏化处理. 引入:玩家在不同情景下可能会选择全屏游戏或窗口化游戏,所以作为开发者,应该在设置中加入全屏与否的选项. 两种插件:screenfull.js与Fullscreen.js 1 ...