字符串大小写转化,有序数组二分查找个人心得等若干内容

news2024/11/16 18:11:12

tips

1. 在电脑里面,任何一切字符,当一看到的时候,脑子里面就要把它转化成ACSII值。如while('0'),可以实现死循环。

2. 统计整形数组的长度不能用strlen(),别一天到晚用到底,strlen统计的是字符数组的长度

3. unsigned 是无符号数,int是有符号数。二者占空间大小相同, 区别是最高位,int表示符号位,而unsigned表示数据位。所以,int可以表示负数,而unsigned不能. 当unsigned可以表示的正数范围比int大一倍.

4.  注意操作符的控制求值顺序,比如说||与&&的短路现象

5. .(点操作符)与*这两个操作符的优先级还是点号来的高。所以有时候在访问结构体成员的时候,*p.a错误,(*p).a可以,但是*(pa).a也是错误的

6. 

一个简单的字符串内大小写字母转化器

代码:

#include <stdio.h>
#include <string.h>
int main()
{
	char arr[20] = { 0 };
	int num = 0;
	do
	{
		printf("请输入一个字符串:");
		gets(arr);
		int sz = strlen(arr);
		int i = 0;
		//
		printf("请选择:1.所有大写字母化为小写。2.所有小写字母化为大写。\n");
		printf("请输入数字(按0退出):");
		scanf("%d", &num);
		getchar();
		if (num == 1)
		{
			for (i = 0; i < sz; i++)
			{
				if ((*(arr + i) >= 'A') && (*(arr + i) <= 'Z'))
				{
					*(arr + i) += ('a' - 'A');
				}
			}
			printf("%s\n", arr);
		}
		else if (num == 2)
		{
			for (i = 0; i < sz; i++)
			{
				if ((*(arr + i) >= 'a') && (*(arr + i) <= 'z'))
				{
					*(arr + i) += ('A' - 'a');
				}
			}
			printf("%s\n", arr);
		}
	} while (num);
	printf("退出成功\n");
	return 0;
}

演示效果:


 

经验总结:

1. 在字符串内部所谓的\0与\n其实编译器都把它看成两个字符。
2. 对于字符串的操作,指针与\0一直都是灵魂所在。
3. 之前也讲过,char虽然是字符类型,但是其本质上也是一个整形。因为在计算机内存当中,根本就存储不了肉眼能看见的字符,而是根据ASCII码表把它转化成对应的十进制整数,因此有一些操作的话就大胆的去弄。事实上,你看见一个字符,在你眼睛里面它就是一个数字。
4. 在ASCII表里面,所有的大写字母与小写字母的值都相差一样,并且所有的大写字母与小写字母都是连续的。 

5. scanf读取的时候是不能够丢掉\n的,因此如果有时候不清理输入缓冲区的话,会出现一些bug。

数字在有序数组中出现的次数

题目链接:https://www.nowcoder.com/practice/70610bf967994b22bb1c26f9ae901fa2?tpId=13&tqId=23274&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目:

代码1(二分法1)

/**
 * 
 * @param data int整型一维数组 
 * @param dataLen int data数组长度
 * @param k int整型 
 * @return int整型
 */
int GetNumberOfK(int* data, int dataLen, int k ) 
{
    int left=0;
    int right=dataLen-1;
    while(left<=right)
    {
        int mid=(left+right)/2;
        if (*(data+mid)>k)
        {
            right=mid-1;
        }
        else if (*(data+mid)<k)
        {
            left=mid+1;
        }
        else
        {
            int num1=1;
            int num2=1;
            while((*(data+mid+num1)==k)&&(mid+num1<dataLen))
            {
                num1++;
            }
            while((*(data+mid-num2)==k)&&(mid-num2>=0))
            {
                num2++;
            }
            return num1+num2-1;
        }
    }
    return 0;
}

经验总结:

1. 对于一个有序数组(并不需要严格升序或降序),用二分查找是一个十分常用的方法。那么既然说起二分查找,套路肯定万变不离其宗,设定一个左端点与右端点,然后再取中间值并且进行一系列的比较。
2. 上面是第一种方法,当中间值恰好为要查找的数时,这时候就以此为原点向左右两边扩展。

代码2(二分法2)

/**
 * 
 * @param data int整型一维数组 
 * @param dataLen int data数组长度
 * @param k int整型 
 * @return int整型
 */
int bisearch(int* data, int dataLen, double num)
{
    int left=0;
    int right=dataLen-1;
    while(left<=right)
    {
        int mid=(left+right)/2;
        if (*(data+mid)>num)
        {
            right=mid-1;
        }
        else
        {
            left=mid+1;
        }
    }
    return left;
}
int GetNumberOfK(int* data, int dataLen, int k ) 
{
    return bisearch(data,dataLen,k+0.5)-bisearch(data,dataLen,k-0.5);
}

经验总结:

1. 这种二分查找的操作确实让我第一次见(实属眼界有限),对此,我总结了一些关于二分查找的个人心得。

不得不回顾一下这题

旋转数组的最小数字

题目链接:https://www.nowcoder.com/practice/9f3231a991af4f55b95579b44b7a01ba?tpId=13&tqId=23269&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking

题目:

 

代码:

/**
 * 
 * @param rotateArray int整型一维数组 
 * @param rotateArrayLen int rotateArray数组长度
 * @return int整型
 */
int minNumberInRotateArray(int* rotateArray, int rotateArrayLen ) 
{
    int left=0;
    int right=rotateArrayLen-1;
    while(left<=right)
    {
        int mid=(left+right)/2;
        if (*(rotateArray+mid)>*(rotateArray+right))
        {
            left=mid+1;
        }
        else if (*(rotateArray+mid)<*(rotateArray+right))
        {
            right=mid;
        }
        else
        {
            right--;
        }
    }
    return *(rotateArray+left);
}

 经验总结:

1. 二分查找目前个人心得:

整数转换

题目链接:https://leetcode.cn/problems/convert-integer-lcci/ 

题目:

代码:

int convertInteger(int A, int B)
{
    unsigned int n=A^B;
    int count=0;
    while(n)
    {
        n=n&(n-1);
        count++;
    }
    return count;
}

经验总结:

1. 这道题说起整数的二进制位之前的转换。说白了,其实就是去找这两个整数的二进制表示形式中到底有几位不同。
2. 对于两个二进制表示形式,按位异或是个显而易见的选择。
3. 当^之后,接下来就是去思考这个结果(二进制序列)到底有多少个1。
(顺便提一下,用int去接受结果可能会出现bug,要用unsigned int去接收,这样的话原先的符号位不再是了,变成了实实在在的数据位)
4. 接下来问题就回归成了求一个二进制序列的1的个数。
这个时候用神奇的表达式n&(n-1)执行一次物理消灭一个1并且计着数就OK了。

 

 

 

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

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

相关文章

在wsl下开发T113的主线linux(1)-准备wsl开发环境

首先在win10或win11下安装wsl&#xff0c;选择wsl1或者wsl2都可以&#xff0c;wsl2的性能更高一些&#xff0c;wsl1的跨系统文件操作速度更快一些&#xff0c;我这里因为有一些工程在win文件系统下&#xff0c;所以选择了wsl1&#xff0c;发行版使用最新的Ubuntu 22.04.01 LTS。…

MySQL隐式转换

隐式转换概念 When an operator is used with operands of different types, type conversion occurs to make the operands compatible. Some conversions occur implicitly. 当运算符与不同类型的操作数一起使用时&#xff0c;将进行类型转换以使操作数兼容。某些转换是隐式发…

2022年年终总结---新方向,新期待

2022年行将结束&#xff0c;回首年初立下的flag&#xff1a; (1)完成OpenCoord版本升级&#xff0c;增加ITRF框架及历元转换、EGM2008查询功能&#xff1b; (2)完成多波束开源项目的数据读取和显示操作。 任务(1)已经完成了&#xff0c;任务&#xff08;2&#xff09;没有完成。…

力扣(LeetCode)2351. 第一个出现两次的字母(C++)

哈希集合 开哈希集合&#xff0c;遍历字符串&#xff0c;未出现的字母加入哈希集合&#xff0c;如果字母出现过&#xff0c;返回这个字母即可。 class Solution { public:char repeatedCharacter(string s) {unordered_set<char> S;for(auto &c:s)if(!S.count(c)) …

第二证券|72家公司接待机构过千,迈瑞医疗热度“断层领先”

2022年最终一个交易日&#xff0c;沪指以红盘收官&#xff0c;但年内A股商场震荡起伏&#xff0c;三大指数均收跌&#xff0c;其间&#xff0c;沪指全年下跌15%&#xff0c;创业板指跌近三成。 调研活动是出资者挖掘上市公司信息的重要来源&#xff0c;是洞悉商场主力资金意向的…

记录NCNN Yolov5部署华为鸿蒙系统踩过的坑

目录 踩坑一&#xff1a;Android Studio连接鸿蒙系统踩过的坑 踩坑二&#xff1a;配置Android studio环境 踩坑三&#xff1a;打开文件夹的位置 踩坑四&#xff1a;No toolchains found in the NDK toolchains folder for ABI with prefix: arm-linux-androideabi 总结 踩…

使用 Bitnami Helm 安装 Kafka

服务器端 K3S 上部署 Kafka Server Kafka 安装 &#x1f4da;️ Quote: charts/bitnami/kafka at master bitnami/charts (github.com) 输入如下命令添加 Helm 仓库&#xff1a; > helm repo add tkemarket https://market-tke.tencentcloudcr.com/chartrepo/opensource-…

LinuxShell注意事项

Linux 介绍 内存 虚拟内存 = 物理内存 + 交换空间 交换空间 = 交换空间 当用户访问某一个程序内存时,需要访问物理内存,而不是交换内存,如果物理内存没有,而交换内存有,则会将交换内存中的程序 加载进物理内存供用户使用,同样,当一个程序长期未访问,内核会将物理内…

【Mongoose笔记】Websocket 服务器

【Mongoose笔记】Websocket 服务器 简介 Mongoose 笔记系列用于记录学习 Mongoose 的一些内容。 Mongoose 是一个 C/C 的网络库。它为 TCP、UDP、HTTP、WebSocket、MQTT 实现了事件驱动的、非阻塞的 API。 项目地址&#xff1a; https://github.com/cesanta/mongoose学习 …

Chromium Embedded Framework(CEF)源码编译基于windows

1.打开维基百科CEF主页: Chromium Embedded Framework - Wikipedia 2.找到CEF仓库地址:chromiumembedded / cef — Bitbucket 打开CEF源码仓库: 点击 Wiki,然后在 Getting Started节,点击cef-project 向下拉浏览滚动条,可看到Setup章节

第三十二讲:神州交换机和路由器上分别实现QoS

QoS&#xff08;Quality of Service&#xff0c;服务品质保证&#xff09;是指一个网络能够利用各种各样的技术向选定的网络通信提供更好的服务的能力。QoS是服务品质保证&#xff0c;提供稳定、可预测的数据传送服务&#xff0c;来满足使用程序的要求&#xff0c;QoS不能产生新…

深入浅出闭包

目录 一、闭包概念 二、重载operator() 三、lambda表达式 3.1 lambda表达式介绍 3.2 lambda表达式语法 3.2.1 [capture-list]捕捉列表 3.2.2(parameters)&#xff1a;参数列表 3.2.3 mutable关键字 3.2.4 ->returntype&#xff1a;返回值类型 3.2.5 {statement}&a…

基于OpenSSL的安全Web Server实现

目录 一、实验目的 二、实验软硬件要求 三、实验预习 四、实验内容&#xff08;实验步骤、测试数据等&#xff09; 实验步骤 1编辑代码 2解决报错 3准备网页 五、实验体会&#xff08;遇到的问题及解决方法&#xff09; 六、服务器代码 七、测试网页代码 一、实验目…

(02)Cartographer源码无死角解析-(43) 2D栅格地图→

讲解关于slam一系列文章汇总链接:史上最全slam从零开始&#xff0c;针对于本栏目讲解(02)Cartographer源码无死角解析-链接如下: (02)Cartographer源码无死角解析- (00)目录_最新无死角讲解&#xff1a;https://blog.csdn.net/weixin_43013761/article/details/127350885 文末…

利用Python构建Wiki中文语料词向量模型

利用Python构建Wiki中文语料词向量模型试验 完整代码下载地址&#xff1a;利用Python构建Wiki中文语料词向量模型 本实例主要介绍的是选取wiki中文语料&#xff0c;并使用python完成Word2vec模型构建的实践过程&#xff0c;不包含原理部分&#xff0c;旨在一步一步的了解自然语…

CH450/TM1637 驱动调试

CH450&#xff1a;支持带有中断的扫描键盘、数码显示&#xff1b; TM1637&#xff1a;键盘扫描/数码显示&#xff1b; CH450/TM1637 I2C的时序调试有问题&#xff0c;总体上注意以下几点 MSB还是LSB&#xff0c;这两个不一样&#xff1b;&#xff08;TM1637从低到高传输&…

PhpStorm 使用全局搜索得不到结果

一、前言二、解决一、前言 全文搜索快捷键&#xff1a;ctrl shift f&#xff0c;如果 没有弹出搜索框。看下快捷键是不是被其他软件占用了&#xff1a;比如搜狗输入法现在的问题是&#xff1a;输入想要搜索的关键字&#xff0c;但是没用搜出来结果&#xff08;实际上关键字在…

BurpSuite与Xray联动进行被动扫描实战

今天继续给大家介绍渗透测试相关知识&#xff0c;本文主要内容是BurpSuite与Xray联动进行被动扫描实战。 免责声明&#xff1a; 本文所介绍的内容仅做学习交流使用&#xff0c;严禁利用文中技术进行非法行为&#xff0c;否则造成一切严重后果自负&#xff01; 再次强调&#xf…

Linux权限及其理解

文章目录&#xff1a;Linux权限的概念Linux权限管理文件访问者的分类&#xff08;人&#xff09;文件类型和访问权限&#xff08;事物属性&#xff09;文件权限值的表示方法文件访问权限的设置方法权限掩码目录的权限粘滞位总结Linux权限的概念 与其它系统相比&#xff0c;Lin…

文件包含漏洞渗透与攻防(一)

目录 前言 什么是文件包含漏洞 文件包含漏洞类型 本地文件包含 远程文件包含 PHP相关函数和伪协议 函数 PHP伪协议 CTF题目案例 文件包含漏洞挖掘与利用 URL关键字 代码审计 利用流程 文件包含漏洞修复方案 前言 随着网站业务的需求&#xff0c;程序开发人员一…