2023年c语言程序设计大赛

news2025/1/11 5:39:30

7-1 这是一道送分题

为了让更多的同学参与程序设计中来,这里给同学们一个送分题,让各位感受一下程序设计的魅力,并祝贺各位同学在本次比赛中取得好成绩。

注:各位同学只需将输入样例里的代码复制到右侧编译器,然后直接提交即可。

输入格式:

无。

输出格式:

无。

输入样例:

#include<bits/stdc++.h>
using namespace std;
int main(){
    int i,j,k,l,m;
    char c='/*';
    cout<<endl;
    for (i=1;i<=3;i++){ 
    for (j=1;j<=32-2*i;j++)
      cout<<" ";
    for (k=1;k<=4*i+1;k++)
      cout<<c;
    for (l=1;l<=13-4*i;l++)
      cout<<" ";
    for (m=1;m<=4*i+1;m++)
      cout<<c;
    cout<<endl;
}
    for (i=1;i<=3;i++){
         for (j=1;j<=24+1;j++)
              cout<<" ";
        for (k=1;k<=29;k++)
              cout<<c;
        cout<<endl;
    }
    for (i=7;i>=1;i--){ 
        for (j=1;j<=40-2*i;j++)
              cout<<" ";
        for (k=1;k<=4*i-1;k++)
              cout<<c;
        cout<<endl;
  }
    for (i=1;i<=39;i++)
        cout<<" ";
    cout<<c<<endl;
    return 0;
}

输出样例:

这里为输入样例的代码运行出来的结果,不嫌麻烦的同学也可以使用printf对下面的结果一行一行去输出。


                              *****         *****
                            *********     *********
                          ************* *************
                         *****************************
                         *****************************
                         *****************************
                          ***************************
                            ***********************
                              *******************
                                ***************
                                  ***********
                                    *******
                                      ***
                                       *
#include<bits/stdc++.h>
using namespace std;
int main(){
    int i,j,k,l,m;
    char c='/*';
    cout<<endl;
    for (i=1;i<=3;i++){ 
    for (j=1;j<=32-2*i;j++)
      cout<<" ";
    for (k=1;k<=4*i+1;k++)
      cout<<c;
    for (l=1;l<=13-4*i;l++)
      cout<<" ";
    for (m=1;m<=4*i+1;m++)
      cout<<c;
    cout<<endl;
}
    for (i=1;i<=3;i++){
         for (j=1;j<=24+1;j++)
              cout<<" ";
        for (k=1;k<=29;k++)
              cout<<c;
        cout<<endl;
    }
    for (i=7;i>=1;i--){ 
        for (j=1;j<=40-2*i;j++)
              cout<<" ";
        for (k=1;k<=4*i-1;k++)
              cout<<c;
        cout<<endl;
  }
    for (i=1;i<=39;i++)
        cout<<" ";
    cout<<c<<endl;
    return 0;
}

7-2 求一元二次方程

image.png

如上图,求解该一元二次方程,y=a*x^2+b*x+c。

输入格式:

输出格式:

输出“a=-1,b=-2,c=z”,z对应c的实际值。

注:本题作者已经给你求出a和b的结果,请通过看图得到c的值,并完成正确结果的输出。

输入样例:

在这里给出一组输入。例如:

输出样例:

在这里给出相应的输出。例如:

a=-1,b=-2,c=0
#include<bits/stdc++.h>
using namespace std;
int main(){
     cout<<"a=-1,b=-2,c=3";
    return 0;
}

 7-3 求积分

image.png

输入格式:

输入一个数x,求上述不定积分,常数项C请忽略。

输出格式:

保留两位小数输出结果。

输入样例:

在这里给出一组输入。例如:

2

输出样例:

在这里给出相应的输出。例如:

4.00
#include<bits/stdc++.h>
using namespace std;
int main(){
	 double x,y=0;
	cin>>x;
	if(x>1||(x>-1&&x<0))y=pow(x,4)/4;
	else y=pow(x,2)/2;
	 printf("%.2f",y);
	return 0;
} 
#include<bits/stdc++.h>
using namespace std;
int main(){
	 double x,z,y=0;
	cin>>x;
    z=x*x*x;
	if(x<z)y=pow(x,4)/4;
	else y=pow(x,2)/2;
	 printf("%.2f",y);
	return 0;
} 

 

7-4 小袁的X

小袁想出一道循环输出图形,然后他看到了X,请各位同学告诉他应该怎么输出。

输入格式:

输入一个整数n。

输出格式:

输出一个有n行的“X”型图形。

输入样例1:

在这里给出一组输入。例如:

3

输出样例1:

在这里给出相应的输出。例如:

* *
 * 
* *

输入样例2:

在这里给出一组输入。例如:

4

输出样例2:

在这里给出相应的输出。例如:

*  *
 ** 
 ** 
*  *

#include<bits/stdc++.h>
using namespace std;
int main(){
      int a;
    cin>>a;
        for(int i=1;i<=a;i++)
		{
            for(int j=a;j>=1;j--)
			{
                if((i+j==a+1)||(i==j))  printf("*");
				else   printf(" ");
            }
            printf("\n");
        }
    return 0;
}

7-5 字符串的删除与排列

你了解回文串嘛?简单来说回文串指正读和反读都是一样的字符串。例如:“abba”是一个回文串,“abca”则不是。现在我们需要对回文串进行一个“简单”操作,我相信每个同学都能够做到。
操作:你需要做的操作是在一串N长度的字符串中删除K个字符,任意排列此字符串能否使它成为回文串,如果能输出YES,不能输出NO

输入格式:

第一行给出T(T < 100)组测试数据。
接下来每组测试输入一个N(1 <= N <= 1e5)和 K(0 <=k <= N)。
下一行输入一个长度为N的字符串进行上述操作。

输出格式:

按照样例即可。

输入样例1:

1
1 0
b

输出样例1:

在这里给出相应的输出。例如:

YES

输入样例2:

10
1 0
a
2 0
ab
2 1
ba
3 1
abb
3 2
abc
6 2
bacacd
6 2
fagbza
6 2
zwaafa
7 2
taagaak
14 3
ttrraakkttoorr

输出样例1:

在这里给出相应的输出。例如:

YES
NO
YES
YES
YES
YES
NO
NO
YES
YES
#include<bits/stdc++.h>

using i64 = long long;
using u64 = unsigned long long;

#define IOS std::ios::sync_with_stdio(false), std::cin.tie(nullptr), std::cout.tie(nullptr)
#define all(v) (v).begin(),(v).end()
void debug(std::vector <int> &a, int n){for (int i = 1; i <= n; i ++){std::cout << a[i] << " \n"[i == n];}}
void YES(){std::cout << "YES\n";}
void NO(){std::cout << "NO\n";}
void Yes(){std::cout << "Yes\n";}
void No(){std::cout << "No\n";}
void yes(){std::cout << "yes\n";}
void no(){std::cout << "no\n";}

const int N = 2e5 + 10;
constexpr i64 mod1 = 998244353, mod2 = 1e9 + 7;

//先独自构造出一个回文串看需要的是否满足,然后有单的尽量再放一个进去,与需要的字符个数进行判断即可

void solve(){
	int n, k;
	std::string s;
	std::cin >> n >> k >> s;

	if (n - k == 1){
		YES();
		return ;
	}

	std::map <char, int> mp;
	int need = n - k;
	for (auto x : s){
		mp[x] ++;
	}

	int ans = 0, dan = 0;
	for (auto [x, y] : mp){
		ans += y / 2;
		if (y % 2){
			dan ++;
		}
	}

	int res = ans * 2 + (dan > 0 ? 1 : 0);
	if (res >= need){
		YES();
	}else {
		NO();
	}
}

int main()
{
    IOS;

    int _;
    std::cin >> _;
    
    while (_ --) solve();

    return 0;
}

 7-6 钟离的尘世一日闲游

海灯节快到了,往生堂陆陆续续开始组织员工们进行休假,今天就轮到了钟离。对这种难得一次的休假,钟离已经做好了尘世闲游的规划,当假期批准时就踏上了旅程。在路经石门时,他发现这次出门又没有带摩拉,而石门距离邻国蒙德已经不远了,于是钟离决定去蒙德寻找温迪帮忙。由于两国之间还存在多条关口路径,且只能够经由若干个关口路经才可能到达蒙德,钟离想知道这些关口之间是不是互相连通的,以便他判断是否可以从任意关口出发最终都可以到达蒙德,现在已知两地之间共有N个关口(关口从1N编号),这些关口之间存在M条关口路径。想请你设计程序,帮助钟离判断这些关口是不是互相连通的。

image.png

输入格式:

第一行输入一个正整数N和正整数M(1<=N<=10,0<=M<=10)。

接下来M行,每行输入三个正整数R1R2(1<=R1R2<=M),表示关口R1与关口R2之间存在一条关口路经。

题目保证输入的数据均合法。

输出格式:

如果所有关口都是连通的,那么输出一行”Accept”(引号不输出)。

如果所有关口并不是连通的,那么在一行中输出一个整数S,代表这些关口组成的集合数。

这里给出关口集合的定义:连通的多个关口(也可以只有一个关口)被称为一个关口集合。

比如:

(1)一共有3个关口,其中关口1、2、3是连通的,那么称关口1、2、3是一个关口集合;

(2)一共有3个关口,其中仅关口1、2是连通的,那么称关口1、2是一个关口集合,关口3单独也是一个关口集合。

注:关口集合的子集不能够作为一个关口集合。

输入样例:

4 3
1 2
2 3
1 3

输出样例:

2

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);

using namespace std;
const int MAX=15;
//最大路经数
int p[MAX];
//并查集根节点数组

int find(int);
//建立并查集函数

int main(void){
    IOS;
    int N, M;
      cin>>N>>M;

    for(int i=1;i<=N;i++)        //初始化并查集根节点数组,初始时各个关口节点互不相关
        p[i]=i;

    for(int i=0;i<M;i++){        //输入N个关口路经连通关系
        int R1, R2;
          cin>>R1>>R2;

        p[find(R1)]=find(p[R2]);    //合并关口节点
    }

    int cnt=0;
    for(int i=1;i<=N;i++)
        if(p[i]==i) cnt++;        //对并查集中的集合数计数

    if(cnt==1)
        //如果集合数为1,说明其中所有结点都是连通的
        cout<<"Accept\n";
    else
        //否则不连通,输出集合的个数
        cout<<cnt<<endl;
    return 0;
}



int find(int x){
    if(x!=p[x]) return find(p[x]);
    return p[x];
}

7-7 旋转矩阵

任意输入一个n阶矩阵,将该矩阵旋转 r*90° 后输出。当 r < 0 时逆时针旋转,当 r > 0 时顺时针旋转。例如,当 r = -1 时逆时针旋转90°,当 r = 2 时顺时针旋转180°。

输入格式:

第一行输入两个整数 n 和 r( 1 ≤ n ≤ 1000,-1000 ≤ r ≤ 1000) 。

接下来 n 行,每行输入 n 个整数,表示 n 阶矩阵 。

输出格式:

输出旋转后的矩阵,数字之间间隔一个空格。

输入样例:

在这里给出一组输入。例如:

3 1
1 2 3
4 5 6
7 8 9

输出样例:

在这里给出相应的输出。例如:

7 4 1
8 5 2
9 6 3
#include<bits/stdc++.h>
using namespace std;
const int N = 1010;
int a[N][N], n, r;
void rotate(int r);
int main()
{
    cin >> n >> r;
    for(int i = 0; i < n; i ++)
        for(int j = 0; j < n; j ++)
            cin >> a[i][j];
    if(r < 0) r = (-r)%4==0 ? 0 : 4 - (-r)%4; // 求补数
    else r = r % 4; //求余数
    rotate( r );
        
    return 0;
}
void rotate(int r)
{
    if(r == 0) { // 旋转0°
        for(int i = 0; i < n; i ++) {
            for(int j = 0; j < n; j ++) {
                if(j != 0) cout << " ";
                cout << a[i][j];
            }
            cout << endl;
        }
    } else if(r == 1) { // 旋转90°
        for(int j = 0; j < n; j ++) {
            for(int i = n - 1; i >= 0; i --) {
                if(i != n - 1) cout << " ";
                cout << a[i][j];
            }
            cout << endl;
        }
    } else if(r == 2) { // 旋转180°
        for(int i = n - 1; i >= 0; i --) {
            for(int j = n - 1; j >= 0; j --) {
                if(j != n - 1) cout << " ";
                cout << a[i][j];
            }
            cout << endl;
        }
    } else if(r == 3) { // 旋转270°
        for(int j = n - 1; j >= 0; j --) {
            for(int i = 0; i < n; i ++) {
                if(i != 0) cout << " ";
                cout << a[i][j];
            }
            cout << endl;
        }
    }
}

 7-8 我只想要分

完全赛题目由N个部分组成,每个部分有两个题,分别是A类题和B类题,答题者可从两道题中选一道题作答,两题分数可能不同

现有一位完全AC大佬,对于完全AC大佬的解释我们可以理解为对大佬来说,所有题都是送分题,我们只需要帮助大佬算出他所能取得的最高分数

注意:机制要求最终答题者所选的A类题和B类题题数之差不得大于1

输入格式:

输入首先在第一行给出正整数N,对应完全赛的N个部分

接下来N行每行给出两个正实数,分别为该部分A类题与B类题的分数

输出格式:

输出该场完全赛大佬在合规的情况下所能取得的最高分数,分数要求保留两位小数输出

输入样例:

在这里给出一组输入。例如:

5
2 3
8.05 4
25 24
89 68
25 23

输出样例:

在这里给出相应的输出。例如:

149.05

样例中我们把第2、4、5部分选A类,第1、3部分选B类,结果为3+8.05+24+89+25=149.05

#include<bits/stdc++.h>
using namespace std;
double a,b[10001];
bool com(double a,double b){
	return a>b;
}
int main(){
	int n;
	double sum;
	cin>>n;
	if(n==0){
		cout<<"0.00";
		return 0;
	}
	for(int i=0;i<n;i++){
		cin>>a>>b[i];
		b[i]=b[i]-a;
		sum+=a;
	}
	sort(b,b+n,com);
	for(int i=0;i<n/2;i++){
		sum+=b[i];
	}
	if(n%2){
		sum=max(sum,sum+b[n/2]);
	}
	printf("%.2lf",sum);
	return 0;
} 

 7-9 草元素方碑解密

水神不歪^_^

在提瓦特大陆上总是能够遇见许多元素方碑,这不,孙俊豪带着纳西妲在须弥的雨林里散步时就发现有一处草方碑的解密,走近一看发现是N个元素方碑的排列解密问题,必须要按照固定的排列顺序激活方碑才可以完成这个解密,由于孙俊豪没有看攻略的习惯,他就决定自己动手解密,他打算拿出草稿本写出所有可能的排列,然后一一进行测试,但是人工计算排列的时间成本实在太高了,所以还得交给计算机来实现。由于孙俊豪是个混子,学艺不精,设计不出这种程序,于是现在他想请你帮忙,设计出这样一个程序,帮助他成功解密拿到原石。

image.png

这个解密是这样设计的:

N个元素方碑从左到右依次线性排列,依次编号为1-N2 <= N <= 10),并且每一个方碑都有其对应的基础权值(权值依次为999999999999,.…..)。当元素方碑被点亮时,它对应的实际权值=i×基础权值,其中i代表该元素方碑是第i个被点亮的。最终点亮全部方碑时,系统会计算出全部方碑的实际权值和,以此做出判断。

解密成功的条件是:

N个元素方碑都被点亮并且它们实际权值的合等于Q

注:每一个元素方碑只能被点亮一次。

题目保证最终结果一定有且仅有唯一解。

样例1解释:

第一次点亮编号为2的方碑,此时它的实际权值为1*9999=9999

第二次点亮编号为3的方碑,此时它的实际权值为2*99999=199998

第三次点亮编号为1的方碑,此时它的实际权值为3*999=2997

image.png

输入格式:

第一行输入一个N(表示这是N个元素方碑的解密),第二行输入一个Q(表示解密成功的实际权值合)。

输出格式:

输出孙俊豪解密成功时依次点亮的方碑编号,相邻两个方碑编号之间用“->”连接。

输入样例1:

3
212994

输出样例1:

2->3->1
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,arr[11],visit[11];
ll a[11]={0,999,9999,99999,999999,9999999,99999999,999999999,9999999999,99999999999,999999999999};
ll qsum,quan;
void dfs(int begin){
    if(begin>n){
        qsum=0;
        for(int i=1;i<=n;i++){
            qsum+=i*a[arr[i]];
        }
        if(qsum==quan){
            for(int i=1;i<=n;i++){
                if(i>1) cout<<"->";
                cout<<arr[i];
            }
            return ;
        }
    }else{
        for(int i=1;i<=n;i++){
            if(visit[i]==0){
                arr[begin]=i;
                visit[i]=1;
                dfs(begin+1);
                visit[i]=0;
            }
        }
    }
}
int main()
{
    cin>>n>>quan;
    dfs(1);
    return 0;
}


// #include<bits/stdc++.h>
// using namespace std;
// typedef long long ll;
// ll a[10]={0,999,9999,99999,999999,9999999,99999999,999999999,9999999999,99999999999};
// int main()
// {
//     int n,k;
//     ll s=0;
//     cin>>n;
//     for(ll i=1;i<=n;i++){
//         cin>>k;
//         s+=i*a[k];
//     }
//     //元素方碑数据构造
//     输入:
//         n
//         1 2 3 4
//     输出n个方碑解密-->顺序为1 2 3 4的解密权值和
//     cout<<s;
//     return 0;
// }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1248021.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

电子作业指导书系统如何提高作业人员的培训效率和作业规范

在现代制造业中&#xff0c;提高生产效率和产品质量是企业不断追求的目标。而对于车间员工来说&#xff0c;如何提高生产培训效率和作业规范是一个重要的问题。电子作业指导书系统作为一种新型的生产管理工具&#xff0c;可以有效提高车间员工的生产培训效率和作业规范。本文将…

maven 将Jar包安装到本地仓库

window系统&#xff1a; 注意事项&#xff1a;在windows中&#xff0c;使用mvn指令将jar安装到本地仓库时&#xff0c;一定要将相关资源使用“"”包裹上&#xff0c;不然会报下面的错&#xff1a; mvn install:install-file "-DfileD:\BaiduNetdiskDownload\qianzixi…

全球服的游戏服务器架构设计

全球服的游戏服务器架构设计 版权声明 本文为“优梦创客”原创文章&#xff0c;您可以自由转载&#xff0c;但必须加入完整的版权声明 文章内容不得删减、修改、演绎 相关学习资料见文末 主题 常见服务器端架构划分 不同类型游戏的架构选择与瓶颈 如何设计通用、可伸缩的…

python 爬百度热搜并生成词云

1、爬取百度body存入txt def get_baidu_hot():url "https://top.baidu.com/board?tabrealtime"headers {"User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/58.0.3029.110 Safari/537.3&…

定制手机套餐---python序列

if __name__ __main__:print("定制手机套餐")print("")#定义电话时长&#xff1a;字典callTimeOptions{1:0分钟,2:50分钟,3:100分钟,4:300分钟,5:不限量}keyinput("请输入电话时长的选择编号&#xff1a;")valuecallTimeOptions.get(key)if val…

看完就会,从抓包到接口测试的全过程解析【1500字保姆级教程】

一、为什么抓包 1、从功能测试角度 通过抓包查看隐藏字段 Web 表单中会有很多隐藏的字段&#xff0c;这些隐藏字段一般都有一些特殊的用途&#xff0c;比如收集用户的数据&#xff0c;预防 CRSF 攻击&#xff0c;防网络爬虫&#xff0c;以及一些其他用途。这些隐藏字段在界面…

中国上市公司漂绿程度及其同构指数(多种测算方法,2012-2022年)

数据简介&#xff1a;20 世纪 90 年代开始&#xff0c;国际上关于绿色市场和绿色管理的学术文献日渐丰富&#xff0c;众多企业积极响应碳排放政策的号召&#xff0c;但其中有多少企业是实实在在的进行碳减排技术创新&#xff0c;又有多少企业打着绿色低碳行为的口号来吸引眼球、…

举个栗子!Quick BI 技巧(4):创建面积图

面积图又叫区域图&#xff0c;是在折线图的基础之上形成的, 它将折线图中折线与自变量坐标轴之间的区域使用颜色或者纹理填充&#xff0c;这样一个填充区域我们叫做面积&#xff0c;颜色的填充也可以更好的突出趋势信息。 有数据粉好奇如何使用 Quick BI 来制作面积图&#xf…

CAD图纸管理软件是否支持自定义属性?

CAD图纸管理软件是否支持自定义属性&#xff1f; 彩虹图纸管理软件_图纸管理系统_图纸文档管理软件系统_彩虹EDM【官网】 CAD图纸管理软件 是一种专业用于管理CAD图纸的工具&#xff0c;它可以帮助用户更加方便地管理、分类和检索自己的CAD图纸。在这个软件中&#xff0c;自定…

沃趣班11月月考题目解析

沃趣班11月月考题目解析 1.在oracle中创建用户时&#xff0c;若未设置default tablespace关键字&#xff0c;则oracle将哪个表空间分配给用户作为默认表空间 答案&#xff1a;D.user SQL> create user mytest identified by 123456; SQL> grant connect to mytest; SQL…

【开源】基于Vue和SpringBoot的独居老人物资配送系统

项目编号&#xff1a; S 045 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S045&#xff0c;文末获取源码。} 项目编号&#xff1a;S045&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块三、系统展示四、核心代码4.1 查询社区4…

色彩 (3)AWB问题

#灵感# AWB 的问题&#xff0c;说难其实也不是很难。 前提&#xff1a; 对于特定的光信号输入&#xff0c;设备的输出信号取决于RGB三通道的频率响应&#xff0c;不同的sensor频率响应一般是不同的。QE曲线描述的就是图像传感器的光电转换效率. 1、灰区设置 标定用标准光源灯…

应用场景丨隧道健康监测系统建设,提高隧道的应急措施

在繁忙的城市交通中&#xff0c;隧道作为重要的枢纽&#xff0c;每天承载着大量的车流和人流。然而&#xff0c;隧道内部的环境和结构状况往往难以掌握&#xff0c;给交通安全带来了潜在的隐患。为了解决这一问题&#xff0c;建立隧道健康监测系统势在必行。 根据《交通运输部关…

【Unity入门】碰撞检测

碰撞器由来 1.系统默认会给每个对象(GameObject)添加一个碰撞组件(ColliderComponent)&#xff0c;一些背景对象则可以取消该组件。 2.在unity3d中&#xff0c;能检测碰撞发生的方式有两种&#xff0c;一种是利用碰撞器&#xff0c;另一种则是利用触发器。这两种方式的应用非…

pcr扩增原理中的变性 退火 延申扩增

一、PCR简介 聚合酶链式反应&#xff08;PCR&#xff09;是一种用于放大扩增特定的DNA片段的分子生物学技术&#xff0c;它可看作是生物体外的特殊DNA复制&#xff0c;PCR的最大特点是能将微量的DNA大幅增加。 二、PCR原理 1.背景 DNA的半保留复制是生物进化和传代的重要途…

PHP众筹系统源码+支持报名众筹+商品众筹+无偿众筹+市面上所有的众筹模式 附带完整的搭建教程

大家好啊&#xff0c;罗峰今天来给大家分好用的源码系统了。今天要给大家分享的是一款PHP众筹系统源码。众筹作为一种新型的融资方式&#xff0c;逐渐在市场上占据了重要的地位。从公益众筹到商品众筹&#xff0c;再到股权众筹&#xff0c;各种众筹模式层出不穷。然而&#xff…

水淹七军(递归,又是递归)

北大2023级最强新生问我的&#xff0c;最后他的问题说是重写了一遍就解决了 乐死了&#xff0c;有的时候根本看不出源代码漏了哪里 我的思路是&#xff1a; 一个数组记录本次放水所经过的格子&#xff0c;经过的不再递归 一个数组记录地图上各地点的高度 一个数组记录地图…

string OJ题

目录 1.仅仅反转字母 2.字符串中的第一个唯一字符​编辑 3.字符串最后一个单词的长度 4.替换空格 1.仅仅反转字母 我们可以定义两个变量来表示数组首尾位置的有效字符的下标&#xff0c;然后分别从前和从后向中间遍历&#xff0c;只要遇到字母就停下来&#xff0c;利用库函数…

黑马点评笔记 redis实现优惠卷秒杀

文章目录 难题全局唯一IDRedis实现全局唯一Id 超卖问题问题解决方案乐观锁问题 一人一单 难题 要解决优惠卷秒杀的问题我们要考虑到三个个问题&#xff0c;全局唯一ID&#xff0c;超卖问题&#xff0c;一人一单。 全局唯一ID 用户抢购时&#xff0c;就会生成订单并保存到同一…

从裸机启动开始运行一个C++程序(十四)

前序文章请看&#xff1a; 从裸机启动开始运行一个C程序&#xff08;十三&#xff09; 从裸机启动开始运行一个C程序&#xff08;十二&#xff09; 从裸机启动开始运行一个C程序&#xff08;十一&#xff09; 从裸机启动开始运行一个C程序&#xff08;十&#xff09; 从裸机启动…