面对对象程序设计_task2_1001.A+B Format (20)
Someting about 1001.A+B Format (20)
**问题描述及我所写的代码:click here → **My Task

看到这个题目的时候,我的想法很简单,直接判断直接输出,因为给定的a,b的范围都是在-1,000,000到1,000,000之间,因此a与b的和sum的位数最多只能为7,所以分成需要输出0个(0<= |sum| <= 999)、1个(1000 <= |sum| <= 999999)、2个逗号(1000000 <= |sum| <=2000000)这三种情况,这三种情况都可以用a+b的绝对值|sum|判断:
对于0个逗号的情况,可以直接输出sum;
对于1个逗号的情况,尝试按照"(-)xxx,xxx"的格式输出。先根据a+b为正为负判断是否加负号,接下来前三位为|sum|/1000,后三位为|sum|%1000,注意后面三位需按%03d格式输出。
对于2个逗号的情况,按照"(-)x,xxx,xxx"的格式输出。还是先判断是否加负号,接下来第一位为|sum|/1,000,000,中间三位为|sum|/1,000%1,000,后三位为|sum|%1000,此时中间三位和后三位同样要按%03d格式输出。
在编码过程中,
第一次运行时发现忘了对负数考虑,导致出现-100,-100的情况,后来直接用条件语句判断解决;
第二次时是自己测试时发现有1,10,100的情况,解决方法就是用%03d控制输出。
自此,该题解决。写完随笔草稿的时候也把过了的代码再改进了一些。
这里将代码贴上。
#include<stdio.h>
#include<stdlib.h>
int main(){
int a, b, asum = 0, sum = 0;
scanf("%d %d", &a, &b);
asum = abs(a + b);
sum = a + b;
if(asum < 1000)
printf("%d\n", sum);
else if(1000 <= asum && asum < 1000000)
{
if(sum < 0)
printf("-");
printf("%d,%03d", asum / 1000, asum % 1000);
}
else if(asum >= 1000000)
{
if(sum < 0)
printf("-");
printf("%d,%03d,%03d", asum / 1000000, asum / 1000 % 1000, asum % 1000);
}
return 0;
}
还有一点是,在做完这个题目的时候有一个朋友向我问了他解题中的问题,我也知道了这道题的一种不同于我的思路的做法,一题多解。
他的想法和我相差甚远,因为他是用数组来操作,将a+b的结果保存在数组当中,然后逐个扫描这个结果,根据不同的位数用if语句控制输出 "," , 核心语句大致如下:
for(i = 0; i < n; i++) // n为char型数组str的长度
{
if(((i + 1) % 3 == n % 3) && ((i + 1) != n))
{
putchar(str[i]);
putchar(',');
}
else
{
putchar(str[i]);
}
}
其实看过去,最明显的差别就是理解程度上的不同,因为这道题数的最大位数为7,所以我的做法中的几个条件语句易于理解,而
if(((i + 1) % 3 == n % 3) && ((i + 1) != n))
这个判断语句并不是很容易理解,但是用数组实现也确实很方便。
写到这里的时候灵光一闪,能不能将这个数组反转存到另一个数组,在反转的过程中每3个字符后再存一个",",最后将这个数组反向输出...诶,好像更麻烦,不过还是试着实现了一下:
void swap(char *strin, int len, char *strout)
{
int cnt = 0;
strin += len - 1;
while(len)
{
*strout = *strin--;
strout++;
cnt++;
len--;
if(cnt % 3 == 0 && len)
{
*strout = ',';
strout++;
}
}
}
指针好像理解起来更是有点费劲,继续,在main函数中,
n=strlen(str);
swap(str, n, str2);
for(i = strlen(str2) - 1; i >= 0; i--)
{
printf("%c", str2[i]);
}
printf("\n");
果然,简直麻烦死,还是前面的数组的处理方法比较好。
一段时间之后再回来,印象最深的就是,代码密密麻麻一堆简直看不下去,果断各种空格,各种缩进。另外,一道看似简单的题目,强行越捋思路越复杂,撇开数组,撇开指针,果然还是几个if else判断语句比较好理解...
面对对象程序设计_task2_1001.A+B Format (20)的更多相关文章
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十八周学习总结
1.实验目的与要求 (1) 综合掌握java基本程序结构: (2) 综合掌握java面向对象程序设计特点: (3) 综合掌握java GUI 程序设计结构: (4) 综合掌握java多线程编程模型: ...
- 201771010135 杨蓉庆AND张燕 《面对对象程序设计(java)》第十一周学习总结
1.实验目的与要求 (1) 掌握Vetor.Stack.Hashtable三个类的用途及常用API: (2) 了解java集合框架体系组成: (3) 掌握ArrayList.LinkList两个类的用 ...
- 周强 201771010141《面对对象程序设计(java)》第十周学习总结
---恢复内容开始--- 1.实验目的与要求 (1) 理解泛型概念: (2) 掌握泛型类的定义与使用: (3) 掌握泛型方法的声明与使用: (4) 掌握泛型接口的定义与实现: (5)了解泛型程序设计, ...
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十六周学习总结
1.实验目的与要求 (1) 掌握线程概念: (2) 掌握线程创建的两种技术: (3) 理解和掌握线程的优先级属性及调度方法: (4) 掌握线程同步的概念及实现技术: 一.理论知识 ⚫ 线程的概念 (1 ...
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十五周学习总结
1.实验目的与要求 (1) 掌握Java应用程序的打包操作: (2) 了解应用程序存储配置信息的两种方法: (3) 掌握基于JNLP协议的java Web Start应用程序的发布方法: (5) 掌握 ...
- 201771010135 杨蓉庆/张燕/杨玲《面对对象程序设计(java)》第十四周学习总结
1.实验目的与要求 (1) 掌握GUI布局管理器用法: (2) 掌握各类Java Swing组件用途及常用API 一.理论知识 Swing和MVC设计模式 (1)设计模式(Design patte ...
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十二周学习总结
1.实验目的与要求 (1) 掌握Java GUI中框架创建及属性设置中常用类的API: (2) 掌握Java GUI中2D图形绘制常用类的API: (3) 了解Java GUI中2D图形中字体与颜色的 ...
- 201771010135 杨蓉庆《面对对象程序设计(java)》第十周学习总结
1.实验目的与要求 (1) 理解泛型概念: (2) 掌握泛型类的定义与使用: (3) 掌握泛型方法的声明与使用: (4) 掌握泛型接口的定义与实现: (5)了解泛型程序设计,理解其用途. 一.理论知识 ...
- 201771010135杨蓉庆 《面对对象程序设计(java)》第九周学习总结
第7章 异常.日志.断言和调试 1.实验目的与要求 (1) 掌握java异常处理技术: (2) 了解断言的用法: (3) 了解日志的用途: (4) 掌握程序基础调试技巧: 一.理论知识 1.异常:在程 ...
随机推荐
- Linux 查看内核版本命令的相关说明
hostname 显示主机名称uname -a 显示内核版本详细信息,其中包括主机名称,发行厂商这个命令是看不到的. 如果要看发行版及厂商可使用命令:lsb_release –a uname -a后, ...
- 资料汇总--java开发程序员必备技能
1. 熟练使用Java语言进行面向对象程序设计(面向对象:继承.多态.抽象): 有良好的编程习惯(阿里开发手册 链接:http://pan.baidu.com/s/1dFEA6cT 密码:kqj4 ...
- Mysql5.5升级到5.6步骤详解 小版本大版本
http://blog.csdn.net/i_team/article/details/9935693 小版本升级,先关闭数据库,然后mv直接全部替换掉mysql目录下的bin/ ,lib/ ,sha ...
- 自己实现一个双向绑定的Vue
我们知道双向绑定是Vue的核心之一,接下来我们自己仿照Vue实现一个基本的功能. 项目代码在GitHub上: https://github.com/zhangKunUserGit/zk-vue
- git移除文件夹的版本控制
案例背景:git提交的时候把bin文件下的各种.dll提交上去了,然后每次提交都得提交好多文件,很容易忽略你真正修改的东西,故对这些不必要的东西忽略掉 解决方案:git rm 命令参数 具体实施: 1 ...
- sql 数据库数据 批量判断修改
A表B表相关联 更新B表中的VisitWeek字段值 CCD_PartnerVisit 此为B表 Dell_FiscalWeek 此为A表 UPDATE CCD_PartnerVisit SET ...
- 【redis中键的生存时间(expire) 】
1.redis中可以使用expire命令设置一个键的生存时间,到时间后redis会自动删除它 expire 设置生存时间(单位/秒) pexpire 设置生存时间( ...
- windows10下mysql8.0.11忘记密码的解决办法
首先输入 新开一个cmd窗口,登录mysql,刷新权限表 FLUSH PRIVILEGES; 经过我再次修改密码测试,只用下面这条语句就可以了 ALTER USER 'root'@'localhost ...
- Linux下socket通信和epoll
上一篇博客用多线程实现服务端和多个客户端的通信,但是在实际应用中如果服务端有高并发的需求,多线程并不是一个好选择. 实现高并发的一种方法是IO多路复用,也就是select,poll,epoll等等. ...
- MySQL数据库的回滚失败(JAVA)
这几天在学习MySQL数据的知识,有一个小测试,用来测试数据库的提交和回滚. 刚开始的时候真的没把这个当回事,按照正常的步骤来讲的话,如下所示,加载驱动,获取数据库的连接,并且把数据库的自动提交给关闭 ...