菜鸟刷题Day2
创始人
2025-05-31 06:31:48
0

菜鸟刷题Day2

一.判定是否为字符重排:字符重排

描述
给定两个由小写字母组成的字符串 s1 和 s2,请编写一个程序,确定其中一个字符串的字符重新排列后,能否变成另一个字符串。


解题思路:
这题思路与昨天最后两道类似,可以给定两个数组,将字符的内容加载到数组中,最后判断两个数组内容是否相同即可。

bool CheckPermutation(char* s1, char* s2){	char arr1[256]={'\0'};char arr2[256]={'\0'};int sz1=strlen(s1);int sz2=strlen(s2);if(sz1!=sz2)  //长度不相同肯定不一样return false;	while(*s1!='\0'&&*s2!='\0'){arr1[*s1]+=1;arr2[*s2]+=1;s1++;s2++;}
//数据录入完毕开始判断呗for(int i=0;i<256;i++){if(arr1[i]!=arr2[i])return false;}return true;
}

二.回文排列:回文排列

描述
给定一个字符串,编写一个函数判定其是否为某个回文串的排列之一。
回文串是指正反两个方向都一样的单词或短语。排列是指字母的重新排列。
回文串不一定是字典当中的单词。


解题思路
基数排序的思想是真的好用,所谓回文串其实也是一种堆成图形,也就是说除了对称线上的那个字符以外,其他的字符至少要出现两次并且是偶数次。如果有超过一个字符只出现了一次或者奇数次,那么这个字符串一定无法组成回文串。

bool canPermutePalindrome(char* s)
{int arr[256]={0};//给的测试用例字符串很长,用char会溢出int sz=strlen(s);while(*s!='\0'){arr[*s]+=1;s++;}int count=0;for(int i=0;i<256;i++){if(arr[i]%2==1)//既判断出现1一次又判断奇数次count++;if(count>1)return false;}return true;
}

三.单词缩写:单词缩写

描述
在日常书面表达中,我们经常会碰到很长的单词,比如"localization"、“internationalization"等。为了书写方便,我们会将太长的单词进行缩写。这里进行如下定义:
如果一个单词包含的字符个数达到或者超过10则我们认为它是一个长单词。所有的长单词都需要进行缩写,缩写的方法是先写下这个单词的首尾字符,然后再在首尾字符中间写上这个单词去掉首尾字符后所包含的字符个数。比如"localization"缩写后得到的是"l10n”,“internationalization"缩写后得到的是"i18n”。现给出n个单词,将其中的长单词进行缩写,其余的按原样输出。


解题思路
这个就中规中矩了,将输入的字符串用一个数组存储起来,方便拿到首字符和尾字符。还要对长度判断,如果这个字符串长度不超过十就直接返回原字符。超过十,只要在输出上稍作文章就行。

#include
#includeint main()
{int n=0;char arr[101]={0};while(scanf("%d",&n)!=EOF){scanf("%s",arr);int len=strlen(arr);if(len<10){printf("%s\n",arr);}else{printf("%c%d%c\n",arr[0],len-2,arr[len-1]);}}
}

四.URL化:URL化

描述
URL化。编写一种方法,将字符串中的空格全部替换为%20。假定该字符串尾部有足够的空间存放新增字符,并且知道字符串的“真实”长度。(注:用Java实现的话,请使用字符数组实现,以便直接在数组上操作。)


解题思路
最常规的办法是遍历,如果遇到空格就把空格后面的数据全部往后挪出三个空间,然后插入%20。但是这样效率实在是太低,因为本身遍历就需要N次,如果全是空格,那么每次插入都要挪动。
更好的办法是先遍历得到空格次数,然后使用双指针思想,从后往前逐字符插入。

char *replaceSpaces(char *S,int length)
{int count=0;for(int i=length-1;i>=0;i--){if(S[i]==' ')count++;//统计空格的个数}int r_end=length+count*2;//实际所需数组空间的长度int c_end=length-1;//字符串的末尾S[r_end--]='\0';//先设置字符串结尾标志while(c_end>=0){//从后往前开始遍历替换if(S[c_end]==' '){//当前字符是空格则向末尾添加%20S[r_end--]='0';S[r_end--]='2';S[r_end--]='%';c_end--;continue;}S[r_end--]=S[c_end--];//当前是非空格则直接赋值即可}
return S;
}

但是作为一个刚刚手搓完string的博主,这里还可以提供一种使用C++中的string来解决的办法。
新建一个string对象,如果遇到空格就+=%20,不是空格就直接+=该字符。(这里也可以印证我在string中说的+=比尾插和append好用)

class Solution 
{
public:string replaceSpaces(string S, int length) {string copy="";for(int i=0;iif(S[i]==' '){copy+="%20";}else{copy+=S[i];}}cout<

OK,那么以上就是今天的题目啦。人们总是容易高估短期努力能带来的提升,却低估长期坚持能带来的改变。那么你坚持了吗?

相关内容

热门资讯

数学系职业生涯规划书 数学类职...   数学系职业生涯规划书(一)  数学是解决问题的语言,是所有科学和技术的核心。接受数学教育的优点是...
国贸系职业生涯规划书 国贸专业...   国贸系职业生涯规划书(一)  一、前言:职业规划意义  每一个人都拥有自己的梦想,然而并非每一个...
哲学系职业生涯规划书范文 分析...  哲学系职业生涯规划书(一)  一、前言  未来,掌握在自己手中。踏着时光车轮,我已走到23岁的年轮...
法学系职业生涯规划书 法学职业...   法学系职业生涯规划书(一)  一、前言  从我们走入大学校门到现在已经快要一年了,现在我们的大一...
物流管理专业职业生涯规划书 物... 第一部分 物流管理师职业前景分析  我国物流产业兴起于上世纪 90年代,起步虽晚,但发展势头强劲,到...
小波包分解提取 %% wavelet packet coefficients. 求取小波包分解的各个节点的小波包系数...
算法小抄9-快慢指针 在上一节我们已经讲过了怎么使用快慢指针去寻找链表的中点,这一节我们继续学习快慢指针的进阶用法,快慢指...
机械学院职业生涯规划书 机械工...  机械学院职业规划书(一)  第一章 认识自我  尼采曾说:“聪明的人只要能认识自己,便什么都不会失...
化学系职业规划书范文 化学系大...   化学系职业规划书(一)  一。 前言  社会的发展日异月新,社会的竞争越来越大,大学生越来越多,...
土木工程学院职业生涯规划书 土...   土木工程学院职业生涯规划书(一)  一、前言  莎士比亚曾说过:“人生就是一部作品。谁有生活理想...
利用python写一个gui小... 文章目录前言制作设计自己想要的ui举个例子后记 前言 在上文中我们配置好了GUI编译环境࿰...
体育学院职业规划书 体育学院职...  体育学院职业规划书(一)  我们向往着美好的明天,所以一直为着心中的那个梦而奋斗。大学生职业生涯规...
护理专业职业生涯规划书 我的职...   护理专业职业生涯规划书(一)  一、前言:  开学了,又一批大一的新生步入了象牙塔,在高三饱受折...
【设计模式】23种设计模式之创... 【设计模式】23种设计模式之创建型模式一、单例模式1、是什么?2、单例模式有哪八种方式...
外语学院职业生涯规划书 外语大...   外语学院职业生涯规划书(一)  在已经步入二十一世纪的今天,大学生已经与时代接轨赋予了全新的含义...
基于点云的深度学习方法预测蛋白... 论文题目: 研究背景: 1. 三维空间结构及相关信息可以通过深度图像&...
背叛的签名 与背叛有关的签名 ... 人的一生,最不能忍的就是被自己最亲的人背叛,在签名里,有哪些签名是与背叛有关的呢?下面请欣赏太阳教育...
离别的签名 有关离别的签名 离... 离别的场景,每个人都不想看到,那么,在签名里,有哪些文字是与离别有关的呢?下面请欣赏太阳教育网小编为...
最新或2023(历届)最新分别... 当我们与别人分离的时候,心情会是怎样的呢?你是否需要为自己的签名换上与分别有关的句子呢?下面请欣赏太...
表达与别人分离的个性签名 分开... 当和别人分离的时候,你会用怎样的一句个性签名来表达自己的心情呢?下面请欣赏太阳教育网小编为大家推荐的...