PAT (Basic Level) Practice | 朋友数

如果两个整数各位数字的和是一样的,则被称为是“朋友数”,而那个公共的和就是它们的“朋友证号”。例如 123 和 51 就是朋友数,因为 1+2+3 = 5+1 = 6,而 6 就是它们的朋友证号。给定一些整数,要求你统计一下它们中有多少个不同的朋友证号。

输入格式

输入第一行给出正整数 N。随后一行给出 N 个正整数,数字间以空格分隔。题目保证所有数字小于10的四次方 。

输出格式:

首先第一行输出给定数字中不同的朋友证号的个数;随后一行按递增顺序输出这些朋友证号,数字间隔一个空格,且行末不得有多余空格。

输入样例

8
123 899 51 998 27 33 36 12

输出样例

4
3 6 9 26

Code

链表法

其实,那时候我怎么写只要是因为看到N没有限制,所以想到了用链表的办法——因为链表也是不加限制的,除非借不到内存了。

#include <stdio.h>
#include <stdlib.h>
typedef struct Node{int num;int summary;struct Node *next;
} Node;
typedef Node* List ;
void addNode(List* list, int num, int *count) {int sum = 0;do sum += num % 10; while((num /= 10) > 0);if(*list) {List last = *list, last1;while(last != NULL) {if(last->num == sum) {last->summary++;goto out;}last1 = last;last = last->next;}Node *p = (Node*)malloc(sizeof(Node));p->num = sum;p->summary = 1;p->next = NULL;last1->next = p;} else {Node *p = (Node*)malloc(sizeof(Node));p->num = sum;p->summary = 1;p->next = NULL;*list = p;}(*count)++;out:;
}
void readList(List* list) {List last = *list;while(last != NULL) {if(last == *list) printf("%d", last->num);else printf(" %d", last->num);last = last->next;}
}
void sortList(List* list) {List last = *list, last1;int temp;while(last != NULL) {last1 = last->next;while(last1 != NULL) {if(last->num > last1->num) {// 交换位置temp = last->num;last->num = last1->num;last1->num = temp;temp = last->summary;last->summary = last1->summary;last1->summary = temp;}last1 = last1->next;}last = last->next;}
}
int main() {List head = NULL;int N, num, count = 0;scanf("%d", &N);for(int i = 0; i < N; i++) {scanf("%d", &num);addNode(&head, num, &count);}printf("%d\n", count);sortList(&head);readList(&head);
}

但是,这实在是太长了,还容易发生错误。
后来,我就想到了第二种方法,就是只用malloc,这样子错误率会降低一些。

连续空间法

#include <stdio.h>
#include <stdlib.h>
typedef struct Node{int num;int summary;
} Node;
int main() {int N, num, sum = 0, count = 0;scanf("%d", &N);Node *List = (Node*)malloc(sizeof(Node)*N), *p = List;for(int i = 0; i < N; i++) {sum = 0;scanf("%d", &num);while(num > 0) {sum += num % 10;num /= 10;}for(Node *q = List; q != p; q++) {if(sum == q->num) {q->summary++;goto out;}}p->num = sum;(p++)->summary = 1;count++;out:;}int temp;for(Node *q = List; q != p; q++) {for(Node *k = q+1; k != p; k++) {if(q->num > k->num) {temp = q->num;q->num = k->num;k->num = temp;temp = q->summary;q->summary = k->summary;k->summary = temp;}}}printf("%d\n", count);for(Node *q = List; q != p; q++) {if(q == List) printf("%d", *q);else printf(" %d", *q);}
}

一些碎碎念

其实,之所以会出现两种方法,是因为前面写链表法的时候,就想到还有更加简单的,但是既然做都做了,总不可能只做一半就放弃吧,结果硬是把它写出来。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/714583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

亿道信息轻工业三防EM-T195,零售、制造、仓储一网打尽

厚度仅10.5mm&#xff0c;重量仅0.65千克的EM-T195&#xff0c;其紧凑而纤薄的设计为以往加固型平板带来了全新的轻薄概念。尽管设计时尚、轻薄&#xff0c;但经过军用认证的强固性仍然能够承受所有具有挑战性的环境条件。随身携带无负担的轻便性加上抗震功能使其成为餐厅、酒店…

C++_数据类型_字符型

作用 字符型变量用于显示单个字符 语法 char ch a;注意 在显示字符型变量时&#xff0c;用单引号将字符括起来&#xff0c;不要用双引号单引号只能有一个字符&#xff0c;不可以是字符串 C和C中字符型变量只占用一个字节字符型变量并不是把字符本身放到内存中存储&#xf…

Excel导出

目录 Maven依赖 实体类 表头列宽自适应处理器 行列冻结处理器 合并单元格处理器 工具类 Maven依赖 <!--easy excel--><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.3.2</vers…

数独游戏(dfs)

代码注释如下 #include <iostream> using namespace std; const int N 10; bool col[N][N], rol[N][N], cell[3][3][N]; char g[N][N]; bool dfs(int x, int y) { //用bool这样在找到一个方案就可以迅速退出if(y 9) x, y 0; //若y超出边界&#xff0c;则第二…

S1---FPGA硬件板级原理图实战导学

视频链接 FPGA板级实战导学01_哔哩哔哩_bilibili FPGA硬件板级原理图实战导学 【硬件电路设计的方法和技巧-哔哩哔哩】硬件电路设计的方法和技巧01_哔哩哔哩_bilibili&#xff08;40min&#xff09; 【高速板级硬件电路设计-哔哩哔哩】 高速板级硬件电路设计1_哔哩哔哩_bil…

【RT-Thread基础教程】邮箱的使用

文章目录 前言一、邮箱的特性二、邮箱操作函数2.1 创建邮箱创建动态邮箱创建静态邮箱 2.2 删除邮箱2.3 发邮件2.4 取邮件 三、示例代码总结 前言 RT-Thread是一个开源的实时嵌入式操作系统&#xff0c;广泛应用于各种嵌入式系统和物联网设备。在RT-Thread中&#xff0c;邮箱是…

输入一个整数,输出其最长连续因子。

输入一个整数&#xff0c;输出其最长连续因子。 例如 输入&#xff1a;60 输出&#xff1a;2 3 4 5 6 注意&#xff1a;1不算因子 输入输出格式 输入描述: 输入一个整数N&#xff0c;N<10000。 输出描述: 输出其最长连续因子&#xff0c;如果有多个最长&#xff0c;输出…

HTML5浮动

1.标准文档流组成 块级元素&#xff08;block&#xff09; 内联元素&#xff08;inline&#xff09; 2.display属性 作用&#xff1a;指定HTML标签的显示方式 常用属性 值 说明 block 块级元素的默认值&#xff0c;元素会被显示为块级元素&#xff0c;该元素前后会带有换行…

Linux UnixODBC安装配置

配置 UnixODBC 梦之上关注IP属地: 香港 0.2322020.12.09 13:23:10字数 1,202阅读 5,447 麒麟&达梦适配系列: 1.麒麟服务器上安装 DM8 2.配置 UnixODBC 3.beego-ORM 适配达梦 资源紧张的时候&#xff0c;服务器是大家共用的&#xff0c;上面部署了一堆服务。所以选用doc…

Lua速成(7)

一、Lua 元表(Metatable) 在 Lua table 中我们可以访问对应的 key 来得到 value 值&#xff0c;但是却无法对两个 table 进行操作(比如相加)。 因此 Lua 提供了元表(Metatable)&#xff0c;允许我们改变 table 的行为&#xff0c;每个行为关联了对应的元方法。 例如&#xf…

ShardingJdbc实战-分库分表

文章目录 基本配置分库分表的分片策略一、inline 行表达时分片策略algorithm-expression行表达式完整案例和配置如下 二、根据实时间日期 - 按照标准规则分库分表标准分片 - Standard完整案例和配置如下 基本配置 逻辑表 逻辑表是指&#xff1a;水平拆分的数据库或者数据表的相…

SpringBoot实战(1)

SpringBoot总结 一,Spring 设计思想 OOP: 面向对象编程-》封装、继承、多态 BOP: 面向Bean编程-》一切从Bean开始 AOP: 面向切面编程-》解藕、专 人做专事 IOC: 控制反转,将new 对象的操作交给Spring统一管理-》转交控制权 DI/DL: 依赖注入/依赖查找-》自动赋值 DI和AOP…

LLVM 一些重要文档 LLVM 3.0

基于LLVM 3.0: Documentation for the LLVM System at SVN head LLVM 作为库的使用方法&#xff1a; Using The LLVM Libraries LLVM C 的编程规范&#xff1a; LLVM Coding Standards

stl 迭代器(Iterator)

定义 迭代器&#xff08;Iterator&#xff09;是STL&#xff08;Standard Template Library&#xff0c;标准模板库&#xff09;中的一个核心概念&#xff0c;用于提供一种通用的方式来遍历容器&#xff08;如vector、list、map等&#xff09;中的元素&#xff0c;而无需暴露容…

大小端问题

0. 介绍 大小端计算机存储数据而安排字节的两种顺序。 针对的是字节。 大端与我们平时书写的顺序一致。 1. 大小端的判定 不需要手动判断。 有一个头文件endian.h; 可能会有宏 __BYTE_ORDER __BIG_ENDIAN __LITTLE_ENDIAN通过库来进行判断。 手动判断 根据字节存取的顺序…

【JSON2WEB】07 Amis可视化设计器CRUD增删改查

总算到重点中的核心内容&#xff0c;CRUD也就是增删改查&#xff0c;一个设计科学合理的管理信息系统&#xff0c;95%的就是CRUD&#xff0c;达不到这个比例要重新考虑一下你的数据库设计了。 1 新增页面 Step 1 启动amis-editor Setp 2 新增页面 名称和路径随便命名&#xf…

Dynamo幕墙探究系列(一)

一直想写个系列教程&#xff0c;但是没有那么多时间整理资料&#xff0c;这次呢&#xff0c;先弄个小系列吧&#xff0c;还是和之前差不多的幕墙测试&#xff0c;我们分几节课&#xff0c;一步一步深入研究。 今天先开个小头儿&#xff0c;要弄的&#xff0c;就是下面这么个模型…

对象锁与类锁

不同锁互不影响&#xff0c;共用一个锁&#xff0c;可能会发生阻塞。 1.在修饰静态方法时&#xff0c;锁定的是当前类的 Class 对象&#xff0c;在下面的例子中就是SycTest1.class 2.当修饰非静态方法时&#xff0c;锁定的就是 this 对象&#xff0c;即当前的实例化对象 public…

【Git教程】(四)版本库 —— 存储系统,存储目录,提交对象及其命名、移动与复制~

Git教程 版本库 1️⃣ 一种简单而高效的存储系统2️⃣ 存储目录&#xff1a;Blob 与 Tree3️⃣ 相同数据只存储一次4️⃣ 压缩相似内容5️⃣ 不同文件的散列值相同6️⃣ 提交对象7️⃣ 提交历史中的对象重用8️⃣ 重命名、移动与复制&#x1f33e; 总结 事实上&#xff0c;我们…

keil MDK安装armcc V5编译器

不知道从什么时候开始&#xff0c;Keil MDK默认不支持V5的编译器了&#xff0c;里面默认只有V6的编译器&#xff0c;设置界面跟V5有很大的差异不太熟悉。最可怕的是&#xff0c;之前使用V5编译的工程&#xff0c;换成V6编译器后居然报错...虽然修改一下应该也可以正常编译&…