一、ASC
题目链接:https://www.lanqiao.cn/problems/1446/learning/
题目要求:已知大写字母 A 的 ASCII 码为 65,请问大写字母 L 的 ASCII 码是多少?
解题思路:不会做的就放弃学编程吧
#include <iostream> using namespace std; int main() { printf("%d",'L'); return 0; }
二、修改数组
题目链接:https://www.lanqiao.cn/problems/185/learning/
题目要求:
给定一个长度为 N 的数组 A=[A 1A 2,⋅⋅⋅,A N ],数组中有可能有重复出现的整数。现在小明要按以下方法将其修改为没有重复整数的数组。小明会依次修改A 2,A 3 ,⋅⋅⋅,A N。当修改 Ai时,小明会检查 A i是否在 A 1 ∼ A i−1 中出现过。如果出现过,则小明会给 A i加上 1 ;如果新的 Ai仍在之前出现过,小明会持续给 A i加 1 ,直 到 A i没有在 A1∼ A_i−1中出现过。当 AN也经过上述修改之后,显然 A 数组中就没有重复的整数了。
现在给定初始的 A 数组,请你计算出最终的 A 数组。
解题思路:
暴力骗分
#include<bits/stdc++.h> using namespace std; int a[100001],n; int main() { scanf("%d",&n); for(int i=0;i<n;i++) { int aa; scanf("%d",&aa); while(a[aa]) { aa++; } printf("%d ",aa); a[aa]=1; } return 0; }
三、大胖子走迷宫
题目链接:https://www.lanqiao.cn/problems/234/learning/
题目要求:
小明是个大胖子,或者说是个大大胖子,如果说正常人占用 1×1 的面积,小明要占用 5×5 的面积。
由于小明太胖了,所以他行动起来很不方便。当玩一些游戏时,小明相比小伙伴就吃亏很多。
小明的朋友们制定了一个计划,帮助小明减肥。计划的主要内容是带小明玩一些游戏,让小明在游戏中运动消耗脂肪。走迷宫是计划中的重要环节。
朋友们设计了一个迷宫,迷宫可以看成是一个由 n×n 个方阵组成的方阵,正常人每次占用方阵中 1×1 的区域,而小明要占用 5×5 的区域。小明的位置定义为小明最正中的一个方格。迷宫四周都有障碍物。
为了方便小明,朋友们把迷宫的起点设置在了第 3 行第 3 列,终点设置在 了第 n−2行第 n−2列。
小明在时刻 0 出发,每单位时间可以向当前位置的上、下、左、右移动单 位 1 的距离,也可以停留在原地不动。小明走迷宫走得很辛苦,如果他在迷宫里面待的时间很长,则由于消耗了很多脂肪,他会在时刻 k 变成一个胖子,只占用 3×3 的区域。如果待的时间更长,他会在时刻 2k 变成一个正常人,只占用 1×1 的区域。注意,当小明变瘦时迷宫的起点和终点不变。
请问,小明最少多长时间能走到迷宫的终点。注意,小明走到终点时可能瘦了也可能没有变瘦。
解题思路:
变种bfs哦,注意体重判断和原地
#include<bits/stdc++.h> using namespace std; const int N = 1001; int n,k; char s[N][N]; int vis[N][N]; int dx[] = {1,0,0,-1}; int dy[] = {0,1,-1,0}; struct node{ int x,y,sj,tx; }; bool pd(int x,int y,int tz) { if(x+tz>n||x-tz<1||y+tz>n||y-tz<0||vis[x][y]) { return false; } for(int i=x-tz;i<=x+tz;i++) { for(int j=y-tz;j<=y+tz;j++) { if(s[i][j]=='*') { return false; } } } return true; } int f(int x) { if(x<k) { return 2; } else if(x<k*2) { return 1; } return 0; } int bfs() { queue<node>q; q.push({3,3,0,2}); vis[3][3] = 1; while(q.size()) { node t = q.front(); q.pop(); if(t.x==n-2&&t.y==n-2) { return t.sj; } if(t.tx!=0) { q.push({t.x,t.y,t.sj+1,f(t.sj+1)}); } for(int i=0;i<4;i++) { int nx = t.x+dx[i]; int ny = t.y+dy[i]; if(pd(nx,ny,t.tx)) { vis[nx][ny] = 1; q.push({nx,ny,t.sj+1,f(t.sj+1)}); } } } } int main() { cin>>n>>k; for(int i=1;i<=n;i++) { for(int j=1;j<=n;j++) { cin>>s[i][j]; } } cout<<bfs(); return 0; }
还有几天 大家加油!