【PAT】1120 Friend Numbers (20 分)

46 篇文章 0 订阅
44 篇文章 0 订阅
  • 题目大意:找到朋友id,即找出所有数各位数之和,然后从小到大输出。

  • 思路:因为set自动排序去重,所以将每个数的各位数之和插入set。

  • 知识点:

    1. set
    2. 如何获得一个int的各位数
  • 代码:

    #include <iostream>
    #include <set>
    
    using namespace std;
    
    set<int> fids;
    
    void find_friend(int num){
    	int f = 0;
    	while(num != 0){
    		f += num % 10;
    		num /= 10;
    	}
    	fids.insert(f);
    }
    
    int main(){
    	int n, num, i, j;
    	scanf("%d", &n);
    	for(i = 0; i < n; i++){
    		scanf("%d", &num);
    		find_friend(num);
    	}
        printf("%d\n", fids.size());
    	for(auto it = fids.begin(); it != fids.end(); it++){
    		if(it == fids.begin())
    			printf("%d", *it);
    		else
    			printf(" %d", *it);
    	}
    	return 0;
    }
    
    
  • 总结:

    1. 没读懂题,之前以为要找到相同数的朋友id,但其实只要找出所有数各位数之和就行了。

    2. 如何获得一个int的各位数:

      int num;
      scanf("%d", &num);
      while(num != 0){
          printf("%d ", num % 10);
          num /= 10;
      }
      
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值