036-字符串

// 036.cpp : Defines the entry point for the console application.
//

#include "stdafx.h"

void DeleteOneStr(char *pBuffer, char str)
{
	if (NULL == pBuffer || str == '\0')
	{
		return;
	}
// 
// 	while(*pBuffer != '\0')
// 	{
// 		if (*pBuffer == str)
// 		{
// 			//*pBuffer = '';
// 			*pBuffer = *(pBuffer+1);
// 		}
// 		pBuffer++;
// 	}

	int i=0;
	for (i=0; pBuffer[i] != '\0'; i++)
	{
		if (pBuffer[i] == str)
		{
			for (int j=i; pBuffer[j]!= '\0'; j++)
			{
				pBuffer[j] = pBuffer[j+1];//删除一个字符相当于把这个字符后的每一个字符向左边移动一位
			}
		}
	}
}


void DeleteStr(char *pBuffer, const char *pStr)
{
	if (NULL == pBuffer || NULL == pStr)
	{
		return;
	}

	const int MAX_SIZE = 256;
	int timesOfBufferCh[MAX_SIZE];//pBuffer每个字符串出现的次数
	int timesOfStrCh[MAX_SIZE];//pStr每个字符串出现的个数
	int i=0;
	int j=0;
	for (i=0; i<MAX_SIZE; i++)
	{
		timesOfBufferCh[i] = 0;
		timesOfStrCh[i] = 0;
	}

	char *pBufferBegin = pBuffer;
	const char *pStrBegin = pStr;
	while(*pBufferBegin != '\0')
	{
		++timesOfBufferCh[*pBufferBegin];
		pBufferBegin++;
	}

	while(*pStrBegin != '\0')
	{
		++timesOfStrCh[*pStrBegin];
		pStrBegin++;
	}

	pBufferBegin = pBuffer;
	while(*pBufferBegin != '\0')
	{
		if(timesOfBufferCh[*pBufferBegin] != 0 && timesOfStrCh[*pBufferBegin] != 0)
		{
			DeleteOneStr(pBuffer, *pBufferBegin);
			pBufferBegin = pBuffer;
			continue;
		}
		pBufferBegin++;
	}
}

void Delete(char *pSrc, const char *pDeleteStr)
{
	if (NULL == pSrc || NULL == pDeleteStr)
	{
		return;
	}

	const int MAX_SIZE = 256;
	int timesOfCh[MAX_SIZE];
	int i=0;
	for (i=0; i<MAX_SIZE; i++)
	{
		timesOfCh[i] = 0;
	}

	while(*pDeleteStr != '\0')
	{
		timesOfCh[*pDeleteStr] = 1;//删除字符里存在的字符其次数记录为1
		pDeleteStr++;
	}

	//每次pFast跳过删除的字符。
	//当不是需要删除的字符时候,把pFast指向的字符赋值给pSlow。同时pFast和pSlow指向下一个字符。当是需要删除的字符时,pFast跳过需要删除的字符
	char *pSlow = pSrc;
	char *pFast = pSrc;
	while(*pFast != '\0')
	{
		if (0 == timesOfCh[*pFast])//无需删除
		{
			*pSlow = *pFast;
			pFast++;
			pSlow++;
		}
		else if (1 == timesOfCh[*pFast])
		{
			pFast++;
		}
	}

	*pSlow = '\0';//最后添加结束符号

}

//题目:输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。
int main(int argc, char* argv[])
{
	char pBuffer[] = "They are students.";
	char pStr[] = "aeiou";
/*****思路1	
	DeleteStr(pBuffer, pStr);
	printf("%s",pBuffer);
**********/

//思路2
	Delete(pBuffer, pStr);
	printf("%s",pBuffer);

	return 0;
}


 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
介绍MD5加密算法基本情况MD5的全称是Message-Digest Algorithm 5,在90年代初由MIT的计算机科学实验室和RSA Data Security Inc发明,经MD2、MD3和MD4发展而来。 Message-Digest泛指字节串(Message)的Hash变换,就是把一个任意长度的字节串变换成一定长的大整数。请注意我使用了"字节串"而不是"字符串"这个词,是因为这种变换只与字节的值有关,与字符集或编码方式无关。 MD5将任意长度的"字节串"变换成一个128bit的大整数,并且它是一个不可逆的字符串变换算法,换句话说就是,即使你看到源程序和算法描述,也无法将一个MD5的值变换回原始的字符串,从数学原理上说,是因为原始的字符串有无穷多个,这有点象不存在反函数的数学函数。 MD5的典型应用是对一段Message(字节串)产生fingerprint(指纹),以防止被"篡改"。举个例子,你将一段话写在一个叫readme.txt文件中,并对这个readme.txt产生一个MD5的值并记录在案,然后你可以传播这个文件给别人,别人如果修改了文件中的任何内容,你对这个文件重新计算MD5时就会发现。如果再有一个第三方的认证机构,用MD5还可以防止文件作者的"抵赖",这就是所谓的数字签名应用。 MD5还广泛用于加密和解密技术上,在很多操作系统中,用户的密码是以MD5值(或类似的其它算法)的方式保存的,用户Login的时候,系统是把用户输入的密码计算成MD5值,然后再去和系统中保存的MD5值进行比较,而系统并不"知道"用户的密码是什么。 一些黑客破获这种密码的方法是一种被称为"跑字典"的方法。有两种方法得到字典,一种是日常搜集的用做密码的字符串表,另一种是用排列组合方法生成的,先用MD5程序计算出这些字典项的MD5值,然后再用目标的MD5值在这个字典中检索。 即使假设密码的最大长度为8,同时密码只能是字母和数字,共26+26+10=62个字符,排列组合出的字典的项数则是P(62,1)+P(62,2)....+P(62,8),那也已经是一个很天文的数字了,存储这个字典就需要TB级的磁盘组,而且这种方法还有一个前提,就是能获得目标账户的密码MD5值的情况下才可以。 在很多电子商务和社区应用中,管理用户的Account是一种最常用的基本功能,尽管很多Application Server提供了这些基本组件,但很多应用开发者为了管理的更大的灵活性还是喜欢采用关系数据库来管理用户,懒惰的做法是用户的密码往往使用明文或简单的变换后直接保存在数据库中,因此这些用户的密码对软件开发者或系统管理员来说可以说毫无保密可言,本文的目的是介绍MD5的Java Bean的实现,同时给出用MD5来处理用户的Account密码的例子,这种方法使得管理员和程序设计者都无法看到用户的密码,尽管他们可以初始化它们。但重要的一点是对于用户密码设置习惯的保护。 作者:佚名 转贴自:http://www.onegreen.net/index.asp 代码修正:未接来电 修正时间:2007年12月27日 未变更前的程序[代码经过格式化和细微BUG处理] import java.security.*; import java.security.spec.*; class Md5 { public final static String MD5(String s) { char hexDigits[] = { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f' }; try { byte[] strTemp = s.getBytes(); MessageDigest mdTemp = MessageDigest.getInstance("MD5"); mdTemp.update(strTemp); byte[] md = mdTemp.digest(); int j = md.length; char str[] = new char[j * 2]; int k = 0; for (int i = 0; i < j; i++) { byte byte0 = md[i]; str[k++] = hexDigits[byte0 >>> 4 & 0xf]; str[k++] = hexDigits[byte0 & 0xf]; } return new String(str); } catch (Exception e) { return null; } } public static void main(String[] args) { System.out.print(Md5.MD5("XX")); } } 变更后的代码请参见:Encrypt.java
001、VB串口通讯视频教程源码41个 002、Visual Basic串口通信工程开发实例导航随书源码7个 003、Visual Basic串口通信与测控应用技术实战详解 源代码(15个全) 004、GE PLC串口通讯,VB编制,读取内存单元 005、PC机与51单片机之间的串口通讯,VB编的,分PC和单片机两部分 006、VB6的串口通信程序,还有crc校验 007、VB Modbus RTU源码,其中协议部分已生成DLL,可直接调用 008、VB.net开发的串口调试程序 009、VB.net实现串口编程,希望大家有用 010、VB版串口调试程序,包含VB源码及安装文件,适合调试串口 011、VB编程RS232串口控制DA数模转换 012、VB编程实现的串口调试工具源码 013、VB编写的RS232串口通信测试程序,以txt格式接受,可定义发送字符 014、VB编写的SouthStar串口测试与51串口烧写器V1.0版 015、VB编写的串口调试助手1.0的源码 016、VB编写的串口短信发送程序,需要数据线支持 017、VB编写的串口通信程序,实现多机通信 018、VB编写的串口通信程序,主要用于上位机与下位机间的通信 019、VB编写的串口通信程序界面参考网上的程序较简单 020、VB编写的串口通讯界面,主要面向51单片机的串口通信 021、VB编写的单片机和PC串口通信的调试程序 022、VB编写的仿真实电子琴操作界面,包含与FPGA串口通信的功能 023、VB串口API通讯,附带BAS文件全部源码,实现与饭卡读卡器通讯 024、VB串口编程,关于上位机的应用,特别适合初级学习VB的学员 025、VB串口编程调试精灵源码 026、VB串口编程实现完整的多费率电表读数软件 027、VB串口程序,,是一个串口使用例程,对初学者有用,特别是工控类的 028、VB串口传输文本,实现2台PC间的通信,类似简单的聊天工具 029、VB串口的一个电子称的项目 030、VB串口调试程序,用于通过串口控制松下空调测试 031、VB串口调试程序及源码 032、VB串口调试软件源代码,可以参考修改为其它通讯程序 033、VB串口调试软件源文件 034、VB串口控制步进电机程序完整源码 035、VB串口通信 6路10位AD转换数据采集源程序 036、VB串口通信,API串口通信模块源码 037、VB串口通信,适用简单,适合初学者 038、VB串口通信操作界面,进行数据采集,画实时曲线 039、VB串口通信程序,可以读取串口并显示保存数据,且能显示数据曲线 040、VB串口通信的源码,学习的好资料 041、VB串口通信调试器的源码程序 042、VB串口通信设计视频演示源码 043、VB串口通信示例 044、VB串口通信数据源码 045、VB串口通信之串口接收程序 046、VB串口通讯测试源代码,有文本和图形两种端口数据观察方式 047、VB串口通讯程序,用来跟单片机通讯 048、VB串口通讯代码(部分) 049、VB串口通讯的参考源程序 050、VB串口通讯实例 高精度电压表(24bit) VB源程序 051、vb串口通讯示例 052、VB串口与伺服电机DSP2407通讯完整代码源程序 053、VB串口源码,动力电池检测数据采集,内含电导巡检模块通讯报文,可,读写,保存,备份数据 054、VB串口字节通信程序,包括:1字节发送子程序,n字节接收子程序 055、VB串行口通信测试示例 056、VB串行通信试验程序 057、VB的MODEM通信源代码,智能化水电远端数据读取系统 058、VB的串口源程序,包括串口的配置界面,接收功能和发送功能 059、VB访问串口,并读取电子秤上显示的数据 060、VB和西门子S7-300 PLC串口通讯程序能实现读写功能 061、VB检测串口工作状态 062、VB简单的串口短信收发功能,使用短信猫测试通过 063、VB开发串口通信,关于生物医学工程专业的血氧饱和度的设计 064、VB开发串口通信软件,利用按钮控件控制高清晰数字展示台 065、VB开发的RS232串口图像处理器驱动(摄像头驱动) 066、VB开发的串口通信源码 067、VB开发的串口与三菱FX PLC通讯源码 068、VB控制串口232通讯,对飞利浦M1卡内数据进行处理,支持密码修改等 069、VB利用Mscomm控件编写的通讯终端,可做串口通讯编程参考示例 070、VB平台单片机与PC机串口通信的PC端程序。小巧易用,功能丰富 071、VB嵌入式串口通讯波形分析显示软件 072、VB实现串口调试LED信息显示屏设备主要代码 073、VB实现串口调试工具的完整源码 074、vb实现串口通信 文件传送系统,用vb以及mscomm控件实现 075、VB实现串口通信,发送命令从而接收相应数据 076、VB使用mscom控件实现PC机与单片机串口通信 077、VB通过COM串口读取条形码设备 078、VB通过串口控制单片机读写24C02源代码 079、VB通讯程序,连接串口可在电脑显示来电号码 080、VB下的串口发短信程序,可选择端口,设置短信中心号码 081、VB写的串口通信,发送和接收实例 082、VB写的串口通信分析程序源码 083、VB写的串口通讯,通过串口对单片机进行控制 084、VB写的串口通讯软件,简单易学,适合初学者 085、VB写的通过串口与考勤机连接通讯的程序 086、vb用控件的写的串口程序,是vb的经典之作 087、VB与USB转串口的通讯完整程序,有详细说明,不需要安装驱动 088、vb与串口通信的关于回路测试的小程序很实用 089、vb语言开发的串口通信,可实现拨号传送文件等 090、VB中串口事件处理函数的示例 091、VB中的串口通讯,串口通讯作为一种古老而又灵活的通讯方式,被广泛地应用 092、VB自动枚举系统串口加摄象头图象采集,坐标系变换 093、Visual Basic2005与自动化系统监控(串并行控制)光盘
整数数据类型之间的区别在于它们能够存储的整数范围大小不同。这些数据类型的区别如下: - tinyint:1 字节,范围为 -128 到 127。 - smallint:2 字节,范围为 -32,768 到 32,767。 - int:4 字节,范围为 -2,147,483,648 到 2,147,483,647。 - bigint:8 字节,范围为 -9,223,372,036,854,775,808 到 9,223,372,036,854,775,807。 浮点数数据类型之间的区别在于它们的精度和存储范围不同。这些数据类型的区别如下: - float:4 字节,单精度浮点数,范围和精度有限。 - double:8 字节,双精度浮点数,范围和精度更大。 - real:4 字节,与 float 相同。 - decimal:存储可变精度的数字,可以指定精度和小数位数。 时间数据类型之间的区别在于它们能够存储的时间范围和精度不同。这些数据类型的区别如下: - date:存储日期,范围为 '1000-01-01' 到 '9999-12-31'。 - time:存储时间,范围为 '-838:59:59' 到 '838:59:59'。 - datetime:存储日期和时间,范围为 '1000-01-01 00:00:00' 到 '9999-12-31 23:59:59'。 - timestamp:存储日期和时间,范围为 '1970-01-01 00:00:01' 到 '2038-01-19 03:14:07'。 - year:存储年份,范围为 1901 到 2155。 字符串数据类型之间的区别在于它们能够存储的字符长度和存储方式不同。这些数据类型的区别如下: - char:固定长度的字符,最多可以存储 255 个字符。 - varchar:可变长度的字符,最多可以存储 65535 个字符。 文本数据类型之间的区别在于它们能够存储的文本长度不同。这些数据类型的区别如下: - tinytext:最多可以存储 255 个字符。 - text:最多可以存储 65535 个字符。 - mediumtext:最多可以存储 16777215 个字符。 - longtext:最多可以存储 4294967295 个字符。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值