zoukankan      html  css  js  c++  java
  • B1076 Wifi密码 (15分)

    B1076 Wifi密码 (15分)

    下面是微博上流传的一张照片:“各位亲爱的同学们,鉴于大家有时需要使用 wifi,又怕耽误亲们的学习,现将 wifi 密码设置为下列数学题答案:A-1;B-2;C-3;D-4;请同学们自己作答,每两日一换。谢谢合作!!~”—— 老师们为了促进学生学习也是拼了…… 本题就要求你写程序把一系列题目的答案按照卷子上给出的对应关系翻译成 wifi 的密码。这里简单假设每道选择题都有 4 个选项,有且只有 1 个正确答案。
    wifi

    输入格式:

    输入第一行给出一个正整数 N(≤ 100),随后 N 行,每行按照 编号-答案 的格式给出一道题的 4 个选项,T 表示正确选项,F 表示错误选项。选项间用空格分隔。

    输出格式:

    在一行中输出 wifi 密码。

    输入样例:

    8
    A-T B-F C-F D-F
    C-T B-F A-F D-F
    A-F D-F C-F B-T
    B-T A-F C-F D-F
    B-F D-T A-F C-F
    A-T C-F B-F D-F
    D-T B-F C-F A-F
    C-T A-F B-F D-F
    

    输出样例:

    13224143
    

    思考

    8
    A-T B-F C-F D-F	/*1*/
    C-T B-F A-F D-F	/*3*/
    A-F D-F C-F B-T	/*2*/
    B-T A-F C-F D-F	/*2*/
    B-F D-T A-F C-F	/*4*/
    A-T C-F B-F D-F	/*1*/
    D-T B-F C-F A-F	/*4*/
    C-T A-F B-F D-F	/*3*/
    

    我的问题就在这个break,这里是还要继续的,所以就不能break

    我的AC代码

    精简版

    #include<bits/stdc++.h>
    using namespace std;
    int main(void){
    	int n,tmp_pass;
    	scanf("%d",&n);
    	char tmp[4];
    	for(int i=0;i<n;i++){
    		for(int j=0;j<4;j++){
    			scanf("%s", tmp);
    			if(tmp[2]=='T')	{
    				tmp_pass=tmp[0]-'A'+1;
    			}
    		}
    		printf("%d",tmp_pass);
    	}
    	return 0;
    }
    

    中间版本

    #include<bits/stdc++.h>
    using namespace std;
    int main(void){
    	int n,tmp_pass;
    	scanf("%d",&n);
    	int *pass =NULL;
    	pass=new int[n];
    	char tmp[4];
    	for(int i=0;i<n;i++){
    		for(int j=0;j<4;j++){
    			scanf("%s", tmp);
    			//printf("
    %s
    ", tmp);
    			if(tmp[2]=='T')	{
    				//tmp_pass=goal(tmp[0]);
    				tmp_pass=tmp[0]-'A'+1;
    			}
    		}
    		pass[i] = tmp_pass;
    	}
    	for(int i=0;i<n;i++){
    		printf("%d",pass[i]);
    	}
    	delete [] pass;
    	return 0;
    }
    

    别人的AC代码

    【PAT】B1076 Wifi密码(15 分) - 路明天 - 博客园 https://www.cnblogs.com/hebust/p/9491370.html

    /*注意接收字符时缓冲区的换行要接受掉*/
    #include<stdio.h>
    int main()
    {
        int n;
        scanf("%d", &n);
        n *= 4;
    
        while(n--) {
            char topics, ans;
            scanf(" %c-%c", &topics, &ans);
            if (ans == 'T')
                printf("%d", topics - 'A' + 1);
        }
        return 0;
    }
    
  • 相关阅读:
    C# Socket编程
    C# Socket编程
    Android基础入门教程
    Android基础入门教程
    SQL Server查询事务
    SQL Server查询事务
    SQL事务用法begin tran,commit tran和rollback tran的用法
    SQL事务用法begin tran,commit tran和rollback tran的用法
    SQL Server Insert操作中的锁
    SQL Server Insert操作中的锁
  • 原文地址:https://www.cnblogs.com/lingr7/p/10294723.html
Copyright © 2011-2022 走看看