A+B for Matrices 及 C++ transform的用法

题目大意:给定两个矩阵,矩阵的最大大小是M*N(小于等于10),矩阵元素的值的绝对值小于等于100,求矩阵相加后全0的行以及列数。

 1 #include<iostream>
 2 using namespace std;
 3 #define N 10
 4 
 5 int main()
 6 {
 7     int n,m,i,j,a[N][N],b[N][N],s;
 8     while(cin>>m)
 9     {   if(m==0) break;
10         cin>>n;
11         for(i=0;i<m;i++)
12             for(j=0;j<n;j++)
13                 cin>>a[i][j];
14         for(i=0;i<m;i++)
15             for(j=0;j<n;j++)
16             {   cin>>b[i][j]; 
17                 a[i][j]+=b[i][j];
18             }
19         s=0;
20         for(i=0;i<m;i++)
21         {   for(j=0;j<n;j++)
22                 if(a[i][j]!=0) break;
23             if(j==n) s++;
24         }
25         for(j=0;j<n;j++)
26         {   for(i=0;i<m;i++)
27                 if(a[i][j]!=0) break;   
28             if(i==m) s++;
29         }
30         cout<<s<<endl;
31     }
32     return 0;
33 }

在网上看到一个大神用纯C++的思想写了如下代码:

 1 #include <iostream>
 2 #include <vector>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 int add(int a, int b){
 7         return a+b;
 8 }
 9 
10 int main(){
11         vector<int> ivec1;
12         vector<int> ivec2;
13 
14         int m, n, sum, data;
15         while(cin >> m){
16                 if(0 == m){
17                         break;
18                 }
19                 cin >> n;
20                 sum = m * n;
21                 for(int i=0; i!=sum; ++i){
22                         cin >>  data;
23                         ivec1.push_back(data);
24                 }
25                 for(int i=0; i!=sum; ++i){
26                         cin >>  data;
27                         ivec2.push_back(data);
28                 }
29                 transform(ivec1.begin(), ivec1.end(), ivec2.begin(), ivec1.begin(), add);
30                 int count = 0;
31                 int temp;
32                 for(int i=0; i!=m; ++i){
33                         temp = 0;
34                         for (int j=0; j!=n; ++j){
35                                 temp += ivec1[i*n + j];
36                         }
37                         if (0 == temp){
38                                 count++;
39                         }
40                 }
41                 for(int i=0; i!=n; ++i){
42                         temp = 0;
43                         for (int j=0; j!=m; ++j){
44                                 temp += ivec1[j*n + i];
45                         }
46                         if (0 == temp){
47                                 count++;
48                         }
49                 }
50                 cout << count << endl;
51                 ivec1.resize(0);
52                 ivec2.resize(0);
53         }
54         return 0;
55 }

 上面出现了transform的用法,在这里介绍下其用法:

 1 /*
 2 template < class InputIterator, class OutputIterator, class UnaryOperator >
 3   OutputIterator transform ( InputIterator first1,    // 源容器的起始地址
 4                             InputIterator last1,    // 源容器的终止地址
 5                             OutputIterator result,    // 目标容器的起始地址
 6                             UnaryOperator op );        // 函数指针
 7 // typedef 目标容器元素类型 (*UnaryOperator)(源容器元素类型);
 8 
 9 template < class InputIterator1, class InputIterator2,
10            class OutputIterator, class BinaryOperator >
11   OutputIterator transform ( InputIterator1 first1,        // 源容器1的起始地址
12                             InputIterator1 last1,        // 源容器1的终止地址
13                             InputIterator2 first2,        // 源容器2的起始地址,元素个数与1相同
14                             OutputIterator result,        // 目标容器的起始地址,元素个数与1相同
15                             BinaryOperator binary_op );    // 函数指针
16 // typedef 目标容器元素类型 (*BinaryOperator)(源容器1元素类型,源容器2元素类型);
17 //*////
18 
19 #include <iostream>
20 #include <algorithm>
21 #include <vector>
22 #include <string>
23 using namespace std;
24 
25 int op_increase (int i)
26 {
27     return i+1; 
28 }
29 
30 int op_sum (int i, int j) 
31 {
32     return i+j; 
33 }
34 
35 int to_upper(int c)
36 {
37     if (islower(c))
38     { 
39         return (c-32); 
40     }
41 
42     return c;
43 }
44 
45 int to_lower(int c)
46 {
47     if (isupper(c))
48     {
49         return c+32;
50     }
51 
52     return c;
53 }
54 
55 int main () {
56     vector<int> first;
57     vector<int> second;
58     vector<int>::iterator it;
59     
60     // set some values:
61     for (int i=1; i<6; i++) first.push_back (i*10); //  first: 10 20 30 40 50
62     
63     ///将first容器的元素加1赋值给second容器
64     second.resize(first.size());        // allocate space !!!必须预先设置一个大小与first相同
65     transform (first.begin(), first.end(), second.begin(), op_increase); // second: 11 21 31 41 51
66     cout << "second contains:";
67     for (it=second.begin(); it!=second.end(); ++it)
68     {
69         cout << " " << *it;
70     }
71     cout << endl;
72     //*
73     
74     ///将first容器的元素与second容器的元素相加,并将得到的结果重新赋值给first
75     transform (first.begin(), first.end(), second.begin(), first.begin(), op_sum); //  first: 21 41 61 81 101
76     cout << "first contains:";
77     for (it=first.begin(); it!=first.end(); ++it)
78         cout << " " << *it;
79     cout << endl;
80     //*//
81 
82     ///大小写转换/
83     string strsrc("Hello, World!");
84     string strdest;
85     strdest.resize(strsrc.size());        // !!!必须预先设置一个大小与strsrc相同
86     transform(strsrc.begin(), strsrc.end(), strdest.begin(), to_upper);    // 转换为大写
87     cout << strdest << endl;
88 
89     transform(strsrc.begin(), strsrc.end(), strdest.begin(), to_lower); // 转换为小写
90     cout << strdest << endl;
91     //*/
92 
93     return 0;
94 }

 

 

 

我们已经了解了一种区间元素交换swap_ranges函数,现在我们再来学习另外一种区间元素交换transform。该算法用于实现容器元素的变 换操作。有如下两个使用原型,一个将迭代器区间[first,last)中元素,执行一元函数对象op操作,交换后的结果放在 [result,result+(last-first))区间中。另一个将迭代器区间[first1,last1)的元素*i,依次与 [first2,first2+(last-first))的元素*j,执行二元函数操作binary_op(*i,*j),交换结果放在 [result,result+(last1-first1))。

     函数原型:

[cpp] view plaincopy
  1. template < class InputIterator, class OutputIterator, class UnaryOperator >  
  2.   OutputIterator transform ( InputIterator first1, InputIterator last1,  
  3.                              OutputIterator result, UnaryOperator op );  
  4.   
  5. template < class InputIterator1, class InputIterator2,  
  6.            class OutputIterator, class BinaryOperator >  
  7.   OutputIterator transform ( InputIterator1 first1, InputIterator1 last1,  
  8.                              InputIterator2 first2, OutputIterator result,  
  9.                              BinaryOperator binary_op );  

     参数说明:

first1, last1
指出要进行元素变换的第一个迭代器区间 [first1,last1)。
first2
指出要进行元素变换的第二个迭代器区间的首个元素的迭代器位置,该区间的元素个数和第一个区间相等。
 
result
指出变换后的结果存放的迭代器区间的首个元素的迭代器位置
op
用一元函数对象op作为参数,执行其后返回一个结果值。它可以是一个函数或对象内的类重载operator()。
binary_op
用二元函数对象binary_op作为参数,执行其后返回一个结果值。它可以是一个函数或对象内的类重载operator()。

      程序示例:

[cpp] view plaincopy
    1. /*******************************************************************   
    2.  * Copyright (C) Jerry Jiang   
    3.  *                  
    4.  * File Name   : transform .cpp   
    5.  * Author      : Jerry Jiang   
    6.  * Create Time : 2012-4-29 22:22:18   
    7.  * Mail        : jbiaojerry@gmail.com   
    8.  * Blog        : http://blog.csdn.net/jerryjbiao    
    9.  *                  
    10.  * Description : 简单的程序诠释C++ STL算法系列之十八                     
    11.  *               变易算法 : 区间元素交换 transform  
    12.  *                  
    13.  ******************************************************************/      
    14. #include <iostream>  
    15. #include <algorithm>  
    16. #include <vector>  
    17. using namespace std;  
    18.   
    19. int op_increase (int i) { return ++i; }  
    20. int op_sum (int i, int j) { return i+j; }  
    21.   
    22. int main () {  
    23.   vector<int> first;  
    24.   vector<int> second;  
    25.   vector<int>::iterator it;  
    26.   
    27.   // set some values:  
    28.   for (int i=1; i<6; i++) first.push_back (i*10); //  first: 10 20 30 40 50  
    29.   
    30.   second.resize(first.size());     // allocate space  
    31.   transform (first.begin(), first.end(), second.begin(), op_increase);  
    32.                                                   // second: 11 21 31 41 51  
    33.   
    34.   transform (first.begin(), first.end(), second.begin(), first.begin(), op_sum);  
    35.                                                   //  first: 21 41 61 81 101  
    36.   
    37.   cout << "first contains:";  
    38.   for (it=first.begin(); it!=first.end(); ++it)  
    39.     cout << " " << *it;  
    40.   
    41.   cout << endl;  
    42.   return 0;  

转载于:https://www.cnblogs.com/heyonggang/p/3263493.html

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

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

相关文章

进程和线程(下)

点击上方“算法猿的成长”&#xff0c;选择“加为星标”第一时间关注 AI 和 Python 知识2019 年第 71 篇文章&#xff0c;总第 95 篇文章本文大约 8000 字&#xff0c;建议收藏阅读上一篇文章介绍了进程和线程的基本概念&#xff0c;以及多进程如何实现&#xff0c;本文则介绍下…

8月总结抽奖

1首先是小小总结下 8 月发文的情况&#xff0c;总共推文时间是 21 天&#xff0c;原创文章有 9 篇&#xff0c;分别如下&#xff1a;Jupyter 进阶教程PyTorch 系列 | 数据加载和预处理教程PyTorch系列 | 如何加快你的模型训练速度呢&#xff1f;Leetcode 系列 | 反转链表PyTorc…

【文件系统】浅解释FAT32

了解完linux下的文件系统之后&#xff0c;顺便对FAT32也研究一下。 假如一个FAT32表如下所示。 文件的簇应该保留在目录中&#xff0c;根据此簇&#xff0c;应该能得到一个块。 要找到文件的下一块&#xff0c;就要根据簇在FAT中寻找&#xff0c;所以FAT中存储的不是本簇的簇号…

全网首发!2020年AI、CV、NLP顶会最全时间表!

点上方蓝字计算机视觉联盟获取更多干货在右上方 设为星标 ★&#xff0c;与你不见不散编辑&#xff1a;Sophia计算机视觉联盟 原创总结 | 公众号 CVLianMeng联盟花费一周对2020年顶会时间进行了总结&#xff01;2020 AI、CV、NLP顶会时间表&#xff0c;包含会议举办的时间、…

互联网大佬学历背景大揭秘,看看是你的老乡还是校友

作者&#xff1a;徐麟&#xff0c;某互联网公司数据分析狮&#xff0c;个人公众号数据森麟&#xff08;id&#xff1a;shujusenlin&#xff09;前言 互联网作为一个快速发展的新兴领域&#xff0c;聚集了大量的优秀人才&#xff0c;前沿技术的广泛应用也不断地为互联网注入着新…

Setup SQL Server 2008 Maintenance Plan Email Notifications

一条龙作完&#xff0c;如何设置EXCHANGE的操作员邮件通知。。 ~~~~ http://808techblog.com/2009/07/setup-sql-server-2008-maintena.html For most of the SQL installs that I maintain, nightly SQL dumps to disk and then copy to tape is my preferred backup method. …

PyTorch | 保存和加载模型教程

点击上方“算法猿的成长”&#xff0c;选择“加为星标”第一时间关注 AI 和 Python 知识图片来自 Unsplash&#xff0c;作者&#xff1a; Jenny Caywood 2019 年第 72 篇文章&#xff0c;总第 96 篇文章总共 7000 字&#xff0c;建议收藏阅读原题 | SAVING AND LOADING MODELS作…

都说dlib是人脸识别的神器,那到底能不能识破妖怪的伪装?

作者&#xff1a;盛光晓原文链接&#xff1a;https://blog.csdn.net/esa72ya/article/details/89189987众所周知&#xff0c;dlib是人脸识别的利器&#xff0c;被广泛应用于行为检测、安防工程、表情分析等&#xff0c;甚至还有学术界的前沿老师将这一技术用于上课点名&#xf…

国内有哪些不错的CV(计算机视觉)团队

点击上方“算法猿的成长”&#xff0c;选择“加为星标”第一时间关注 AI 和 Python 知识来源&#xff1a;知乎问题对于初入 CV 领域的同学&#xff0c;如果可以加入一个不错的团队&#xff0c;有好的导师带着&#xff0c;同时还有可以请教的师兄师姐&#xff0c;会加快入门 CV …

数据全裸时代,你的隐私有多容易获取?

大家好我是痴海&#xff0c;一位转型做增长的爬虫师&#xff0c;由于工作的缘故&#xff0c;对于身边许多信息都非常敏感。上个月朋友圈有很多人都在晒四六级成绩&#xff0c;有人欢喜有人忧愁&#xff0c;而我却感受到深深的恐惧。2018 年腾讯手机管家在一个报告中公布了一个数…

单元测试的一些基本概念

我们&#xff08;程序员&#xff09;多多少少都写过单元测试&#xff0c;有的可能几年前写的几行代码&#xff08;比如我&#xff09;&#xff0c; 姑且也算写过吧&#xff0c;但是有些东西还是不是很清楚&#xff0c;比如什么是单元测试&#xff1f;怎么才算是好的单元测试&am…

深度学习领域有哪些瓶颈

来源&#xff1a;知乎问题深度学习是近年来人工智能热潮的原因&#xff0c;它的出现在很多方面都作出了突破&#xff0c;包括在图像、NLP以及语音等领域都有很多问题取得很大的突破&#xff0c;但它目前也存在一些问题和瓶颈需要解决。量子位https://www.zhihu.com/question/40…