hdoj第2000题c语言答案,hdoj上的一题和程序设计第二次作业的拓展-人见人爱a+b

本文主要是介绍hdoj第2000题c语言答案,hdoj上的一题和程序设计第二次作业的拓展-人见人爱a+b,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

人见人爱a+b

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

人见人爱a+b

#include

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;

}

bfb7ec7214ef0e7efa88c3b80969b592.png

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

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

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

一、A+B*C

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

代码如下:

#include

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

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补充位数。

遇到的问题:

b81e7c15200e3dfab2b0f7551d42a752.png

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

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

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

2016/2/26

程序设计第二次作业&lt&semi;1&gt&semi;

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

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

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

面向对象程序设计 第二次作业&lt&semi;1&gt&semi;

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

expdp 报The value &lpar;30&rpar; of MAXTRANS parameter ignored错误的原因诊断

在使用expdp导出一个表的数据时遇到了下面情况,也不见其提示报错信息,一下子就执行完了,也没有导出我需要的数据 [oracle@getlnx01 dump_dir]$ expdp system/xx ...

javascript里的封装

用javascript闭包的特性,可以模拟实现私有变量.私有方法. var myObject = =(function(){ var privateValue; function privateMet ...

修改emlog表字段名称

在em_twitter表中增加一个字段. ,添加一个字段isImportant alter table em_twitter add isImprotant ) not ; ,把字段isImprota ...

HDU5772 String problem(最大权闭合子图)

题目..说了很多东西 官方题解是这么说的: 首先将点分为3类 第一类:Pij 表示第i个点和第j个点组合的点,那么Pij的权值等于w[i][j]+w[j][i](表示得分) 第二类:原串中的n个点每个 ...

扩展 IEnumerable&lt&semi;T&gt&semi;,让它根据另一个集合的顺序来排列

假如我有两个集合: public class Teacher { public int Id { get; set; } public string Name { get; set; } } publ ...

ylbtech-Unitity-CS&colon;Hello world

ylbtech-Unitity-CS:Hello world 1.A,效果图返回顶部   1.B,源代码返回顶部 1.B.1,Hello1.cs public class Hello1 { publi ...

codeforces&num;253 D - Andrey and Problem里的数学知识

这道题是这种,给主人公一堆事件的成功概率,他仅仅想恰好成功一件. 于是,问题来了,他要选择哪些事件去做,才干使他的想法实现的概率最大. 我的第一个想法是枚举,枚举的话我想到用dfs,但是认为太麻烦. ...

浅谈MVC中的service层(转)

概述 mvc框架由model,view,controller组成,执行流程一般是:在controller访问model获取数据,通过view渲染页面. mvc模式是web开发中的基础模式,采用的是分层 ...

react项目请求数据的fetch的使用

准备三个文件(封装请求函数),然后测试一下,能不能调用数据 第一个文件  request.js import 'whatwg-fetch'; /** * Parses the JSON returne ...

这篇关于hdoj第2000题c语言答案,hdoj上的一题和程序设计第二次作业的拓展-人见人爱a+b的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/221006

相关文章

作业提交过程之HDFSMapReduce

作业提交全过程详解 (1)作业提交 第1步:Client调用job.waitForCompletion方法,向整个集群提交MapReduce作业。 第2步:Client向RM申请一个作业id。 第3步:RM给Client返回该job资源的提交路径和作业id。 第4步:Client提交jar包、切片信息和配置文件到指定的资源提交路径。 第5步:Client提交完资源后,向RM申请运行MrAp

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

poj 3104 二分答案

题意: n件湿度为num的衣服,每秒钟自己可以蒸发掉1个湿度。 然而如果使用了暖炉,每秒可以烧掉k个湿度,但不计算蒸发了。 现在问这么多的衣服,怎么烧事件最短。 解析: 二分答案咯。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <c

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

如何确定 Go 语言中 HTTP 连接池的最佳参数?

确定 Go 语言中 HTTP 连接池的最佳参数可以通过以下几种方式: 一、分析应用场景和需求 并发请求量: 确定应用程序在特定时间段内可能同时发起的 HTTP 请求数量。如果并发请求量很高,需要设置较大的连接池参数以满足需求。例如,对于一个高并发的 Web 服务,可能同时有数百个请求在处理,此时需要较大的连接池大小。可以通过压力测试工具模拟高并发场景,观察系统在不同并发请求下的性能表现,从而

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非