华为7.28笔试

1. 先把不符合要求的去掉,然后按照策略排序,选择前n个,最后再按编号排序,Python代码:
import sys
# sys.setrecursionlimit(1000000)
m = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))
arr = []
for _ in range(m):
    idx,cpuCount,memSize,cpuArch,supportNP = list(map(int,sys.stdin.readline().strip(' ').strip('
').strip(' ').split(',')))
    arr.append([idx,cpuCount,memSize,cpuArch,supportNP])
n,strategy,cpuCount,memSize,cpuArch,supportNP = list(map(int,sys.stdin.readline().strip(' ').strip('
').strip(' ').split(' ')))
remaid_arr= []
for i in range(m):
    if arr[i][1]>= cpuCount and arr[i][2]>=memSize:
        if (cpuArch==9&nbs***bsp;cpuArch==arr[i][3]) and (supportNP==2&nbs***bsp;supportNP==arr[i][4]):
            remaid_arr.append(arr[i].copy())

if strategy==1:
    remaid_arr = sorted(remaid_arr,key=lambda x:[x[1],x[2],x[0]])
else:
    remaid_arr = sorted(remaid_arr,key=lambda x:[x[2],x[1],x[0]])
remaid_arr = remaid_arr[:n]
res = [v[0] for v in remaid_arr]
res = sorted(res)
t = len(res)
res.insert(0,t)
print(" ".join(list(map(str,res))))

2. 拓扑排序:
import sys
# sys.setrecursionlimit(1000000)
m = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))
n = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))
z = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))

arr = []
graph = [[] for _ in range(m+1)]
cnt_in = [0]*(m+1)
cnt_out = [0]*(m+1)
for _ in range(z):
    i,j = list(map(int,sys.stdin.readline().strip(' ').strip('
').strip(' ').split(' ')))
    arr.append([i,j])
    cnt_in[j]+=1
    cnt_out[i]+=1
    graph[i].append(j)

length = [-1]*(m+1)
for i in range(1,m+1):
    def dfs(idx):
        if len(graph[idx])==0:
            length[idx] =0
            return 0
        if length[idx]>=0:
            return length[idx]
        res = 0
        for to in graph[idx]:
            res = max(res,1+dfs(to))
        length[idx] = res
        return res
    dfs(i)

res = 0
book =  [0]*(m+1)
book[0]=1
while True:
    tn = n
    temp_book = [0]*(m+1)
    flag = True
    for _ in range(tn):
        temp_idx = 0
        for i in range(1,m+1):
            if book[i]==0 and temp_book[i]==0 and cnt_in[i]==0 and (temp_idx==0&nbs***bsp;length[temp_idx]<length[i]):
            # if book[i]==0 and temp_book[i]==0 and cnt_in[i]==0 and (temp_idx==0&nbs***bsp;cnt_out[temp_idx]<cnt_out[i]):
                temp_idx =i

        if temp_idx==0:
            break
        flag = False
        book[temp_idx] = 1
        for to in graph[temp_idx]:
            cnt_in[to]-=1
            temp_book[to]=1
    if flag:
        break
    res+=1

print(res)

3. 求路径,需要保证经过图上所以能到达的点,一次且仅一次。我是暴力做的,Python过不了,但是C++可以😂。
Python代码(AC 60%):
import sys
# sys.setrecursionlimit(1000000)
m,n = list(map(int,sys.stdin.readline().strip(' ').strip('
').strip(' ').split(' ')))
# n = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))
# z = int(sys.stdin.readline().strip(' ').strip('
').strip(' '))


graph = []
line_num = 1
start,end = [], []
for i in range(m):
    line = list(map(int,sys.stdin.readline().strip(' ').strip('
').strip(' ').split(' ')))
    graph.append(line)
    for j in range(n):
        v = line[j]
        if v ==0 :
            line_num+=1
        elif v==1:
            start = [i,j]
        elif v==2:
            end = [i,j]
res = [0]
nex = [[0,1],[1,0],[0,-1],[-1,0]]
book = [[0 for _ in range(n)] for _ in range(m)]
def dfs(x,y,temp_line_num,m,n,line_num):
    if x==end[0] and y ==end[1]:
        if temp_line_num== line_num:
            res[0]+=1
        return

    book[x][y]  = 1
    for k in range(len(nex)):
        newx,newy = nex[k][0]+x,nex[k][1]+y
        if 0<=newx<m and 0<=newy<n and book[newx][newy] == 0 and (graph[newx][newy]==1&nbs***bsp;graph[newx][newy]==0&nbs***bsp;graph[newx][newy]==2  ):
            dfs(newx,newy,temp_line_num+1,m,n,line_num)
    book[x][y]= 0

dfs(start[0],start[1],0,m,n,line_num)
print(res[0])


C++(AC 100%):
#include <iostream>
#include <vector>
using namespace std;
int graph[41][41];
int book[41][41];
int res,sx,sy,ex,ey;
int nex[4][2]={{0,1},{1,0},{0,-1},{-1,0}};
void dfs(int x,int y,int temp_line_num,int m ,int n ,int line_num){
    if (x==ex and y==ey){
        if (temp_line_num == line_num){
            res+=1;
        }
        return;
    }
    book[x][y] = 1;
    int newx,newy;
    for (int i = 0; i < 4; ++i) {
        newx= nex[i][0]+x;
        newy = nex[i][1]+y;
        if (0<= newx && newx<m && 0<=newy && newy<n &&book[newx][newy] == 0 && (graph[newx][newy]==1 || graph[newx][newy]==0 || graph[newx][newy]==2)){
            dfs(newx,newy,temp_line_num+1,m,n,line_num);
        }
    }
    book[x][y] =0;
    return;
}
int main() {
    int t;
    int a,b,n,m,line_num=1;
    cin>>m>>n;

    for (int i = 0; i <m ; ++i) {
        for (int j = 0; j <n ; ++j) {
            cin>>graph[i][j];
            if (graph[i][j]==0){
                line_num+=1;
            }
            else if (graph[i][j]==1){
                sx= i;
                sy = j;
            } else if (graph[i][j]==2){
                ex= i;
                ey = j;
            }
        }
    }

    dfs(sx,sy,0,m,n,line_num);
    cout<<res<<endl;

//    std::cout << "Hello, World!" << std::endl;
    return 0;
}


#华为机试##华为##笔试题目#
全部评论
感觉比7.21的难好多,选7.28亏大了
1 回复 分享
发布于 2021-07-29 16:57
谢谢大佬
点赞 回复 分享
发布于 2021-07-29 01:43
请问哪里能看到原题
点赞 回复 分享
发布于 2021-07-29 13:21
我其他语言用的少不熟悉所以都用python写的...最后一题超时,只过了50%。感觉被语言性能拉低了分数好难过...时限给的也太短了,不合理啊
点赞 回复 分享
发布于 2021-07-29 20:21

相关推荐

2024-11-14 15:03
西安电子科技大学 C++
Java抽象带篮子:安卓怎么你了
投递荣耀等公司10个岗位
点赞 评论 收藏
分享
2024-12-20 18:56
已编辑
武汉轻工大学 后端
点赞 评论 收藏
分享
评论
5
37
分享
牛客网
牛客企业服务