1 条题解

  • 0
    @ 2023-6-11 12:17:07

    C :

    #include <stdio.h>
    
    void main(){
    	int a[100][100],b[100][100];
    	int i,j,n,m,c=0;
    	scanf("%d %d",&n,&m);
    
    	for(i=0;i<n;i++){
    		for(j=0;j<m;j++){
    			scanf("%d",&a[i][j]);
    		}
    	}
    
    	for(i=0;i<n;i++){
    		for(j=0;j<m;j++){
    			scanf("%d",&b[i][j]);
    		}
    	}
    
    	for(i=0;i<n;i++){
    		for(j=0;j<m;j++){
    			if(a[i][j]==b[i][j]){
    				c++;
    			}
    		}
    	}
    
    	printf("%.2f",c*100.0/(n*m));
    }
    

    C++ :

    #include <bits/stdc++.h>
    using namespace std;
    
    int main(){
    	int a[110][110],b[110][110];
    	int n,m,i,j,c = 0;//c是计数器
    	cin>>n>>m;
    	for(i = 0;i < n;i++){
    		for(j = 0;j < m;j++){
    			cin>>a[i][j];
    		}
    	}
    	
    	for(i = 0;i < n;i++){
    		for(j = 0;j < m;j++){
    			cin>>b[i][j];
    		}
    	}
    	//求一样的点的数量 
    	for(i = 0;i < n;i++){
    		for(j = 0;j < m;j++){
    			if(a[i][j] == b[i][j]){
    				c++;
    			}
    		}
    	}
    	
    	double r = c * 1.0 / (n * m) * 100;
    	cout<<fixed<<setprecision(2)<<r<<endl;
    	  
        return 0;
    }
    
    

    Python :

    n,m=list(map(int,input().split()))
    a=list()
    b=list()
    for i in range(n):
        a.append(list(map(int,input().split())))
    for i in range(n):
        b.append(list(map(int,input().split())))
    sum=0
    
    for i in range(n):
        for j in range(m):
            if a[i][j]==b[i][j]:
                sum=sum+1
    print("%.2lf"%(100*sum/(n*m)))
    
    
    
    • 1

    信息

    ID
    2327
    时间
    1000ms
    内存
    16MiB
    难度
    (无)
    标签
    递交数
    0
    已通过
    0
    上传者