蓝桥杯Python B组练习——芯片测试

一、题目

问题描述

有n(2≤n≤20)块芯片,有好有坏,已知好芯片比坏芯片多。

每个芯片都能用来测试其他芯片。用好芯片测试其他芯片时,能正确给出被测试芯片是好还是坏。而用坏芯片测试其他芯片时,会随机给出好或是坏的测试结果(即此结果与被测试芯片实际的好坏无关)。

给出所有芯片的测试结果,问哪些芯片是好芯片。
输入格式

输入数据第一行为一个整数n,表示芯片个数。

第二行到第n+1行为n*n的一张表,每行n个数据。表中的每个数据为0或1,在这n行中的第i行第j列(1≤i, j≤n)的数据表示用第i块芯片测试第j块芯片时得到的测试结果 ,1表示好,0表示坏,i=j时一律为1(并不表示该芯片对本身的测试结果。芯片不能对本 身进行测试)。
输出格式

按从小到大的顺序输出所有好芯片的编号
样例输入

3

1 0 1

0 1 0

1 0 1
样例输出

1 3

二、解析

给了总共有多少芯片,如样例中给了3个,在这n行中的第i行第j列(1≤i, j≤n)的数据表示用第i块芯片测试第j块芯片时得到的测试结果,也就是说第一列数据是三个芯片分别对第一块芯片的测试,以此类推。又因为好的芯片测试结果是准确的,并且好的比坏的多,所以好的结果大于总的一半就能确定他是好的芯片。

三、Python代码

复制代码
# 获取输入的总的芯片数
n = int(input())
# 获取输入的测试结果
arr = [list(map(int,input().split())) for i in range(n)]
tmp = [True]*n
for i in range(n):
    count = 0
    for j in range(n):
        if arr[j][i] ==0:
            count+=1
        if count >= n/2:
            tmp[i] = False
            break
for i in range(n):
    if tmp[i]==True:
        print(i+1,end="")

四、运行结果

五、视频讲解

http://【蓝桥杯比赛python组视频教程(零基础讲解+算法辅导)】https://www.bilibili.com/video/BV1Ma411B7TQ?p=11&vd_source=3f9b0ca3fcb4e76e1d57fb85a5746819

六、查漏补缺

双重for循环注意事项:

1.外层循环用来控制行数,内层循环用于控制列数;

2.外层循环的变量改动一次,内层循环需要从头到尾执行一遍(外层循环执行一次,内层循环跑一圈)

3.遇到几行几列时,使用双重循环,循环的嵌套不宜超过3层

end=" "

复制代码
a=0
for i in range(3):
    print()
    for j in range(3):
        a+=1
        print(a)

如上代码,没有end=" "时,运行结果:

有end=" "时运行结果:

七、最近刷到的有关的题

【深基4.习8】求三角形

## 题目描述

模仿例题,打印出不同方向的正方形,然后打印三角形矩阵。中间有个空行。

## 输入格式

输入矩阵的规模,不超过 9。

## 输出格式

输出矩形和正方形

## 样例 #1

### 样例输入 #1

复制代码
4
### 样例输出 #1
01020304
05060708
09101112
13141516

      01
    0203
  040506
07080910

python代码

复制代码
n = int(input())
num=1
for i in range(n):
    for j in range(n):
        print("%02d"%num,end="")
        num+=1
    print()
print()
num=1
for i in range(n):
    print("  "*(n-i-1),end="")
    for j in range(i+1):
        print("%02d"%num,end="")
        num+=1
    print()

运行结果:

相关推荐
独行soc2 小时前
2025年渗透测试面试题总结-阿里云[实习]阿里云安全-安全工程师(题目+回答)
linux·经验分享·安全·阿里云·面试·职场和发展·云计算
程序员小远3 小时前
UI自动化测试方案详解
自动化测试·软件测试·selenium·测试工具·ui·职场和发展·测试用例
小羊在奋斗5 小时前
【LeetCode 热题 100】搜索插入位置 / 搜索旋转排序数组 / 寻找旋转排序数组中的最小值
算法·leetcode·职场和发展
林下清风~7 小时前
力扣hot100——347.前K个高频元素(cpp手撕堆)
算法·leetcode·职场和发展
Swift社区9 小时前
涂色不踩雷:如何优雅解决 LeetCode 栅栏涂色问题
算法·leetcode·职场和发展
洛书千年11 小时前
五月份嵌入式面试总结
面试·职场和发展
蓝婷儿14 小时前
前端面试每日三题 - Day 34
前端·面试·职场和发展
S01d13r18 小时前
LeetCode 解题思路 48(编辑距离、只出现一次的数字)
算法·leetcode·职场和发展
XiaoyaoCarter1 天前
每日一道leetcode(新学数据结构版)
数据结构·c++·算法·leetcode·职场和发展·哈希算法·前缀树
测试界萧萧1 天前
15:00开始面试,15:06就出来了,问的问题有点变态。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展