最近学了栈,和一些心情emmm,11.11

今天毅行简直歌荒了。。。无BGM 不欢的我啊 ,好像跟着那两个移动音响走就有好多力气,加上零食诶嘿嘿嘿
其实中间放了一手很甜的sukinanode,波哥说这不是宅男们喜欢的吗。。。。哈哈哈哈哈
再次觉得土木的小哥哥们都太善良啦。
1.读取数组的长度
字符串长度。
int len=strlen((char*)s);
2.用栈的时候
#include
直接就可以引入接口库了
然后stack k;k.push(s[i]);
k.pop();这样就可以啦。
但是 string不太行,我当时写的时候因为栈里面存的是压进去的嘛所以某浆糊帮我改成了char(嘘)
3.void memset(void s, int ch, size_t n);
将s中当前位置后面的n个字节 (typedef unsigned int size_t )用 ch 替换并返回 s 。
memset:作用是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
来自百度百科
<01>memset函数按字节对内存块进行初始化,所以不能用它将int数组初始化为0和-1之外的其他值(除非该值高字节和低字节相同)。
<02>第三: 搞反了 ch 和 n 的位置.
一定要记住如果要把一个char a[20]清零,一定是 memset(a,0,20
sizeof(char));
而不是 memset(a,20
sizeof(char),0);
第四: 过度使用memset,我想这些程序员可能有某种心理阴影,他们惧怕未经初始化的内存,所以他们会写出这样的代码:

char buffer[4];
memset(buffer,0,sizeof(char)*4);
strcpy(buffer,"123");
//"123"中最后隐藏的'\0'占一位,总长4位


这里的memset是多余的. 因为这块内存马上就被全部覆盖,清零没有意义.
另:以下情况并不多余,因某些编译器分配空间时,内存中默认值并不为0:

char buffer[20];
memset(buffer,0,sizeof(char)*20);
memcpy(buffer,"123",3);
//这一条的memset并不多余,memcpy并没把buffer全部覆盖,如果没有memset,
//用printf打印buffer会有乱码甚至会出现段错误。
//如果此处是strcpy(buffer,"123");便不用memset,
//strcpy虽然不会覆盖buffer但是会拷贝字符串结束符

总之,这个在大佬的代码里看到了,反正不这么写的话,数组没有值,不能直接+=,稍微记一下。那个行列式的题
4.今天的毅行让我意识到想变好的我其实只是需要一个支点和坚持下去的动力罢了。(躺的表情)
嗯我还是找点固定的事情去做(给满分)今天还看到了martini,感觉精弘是个很好的地方虽然我水到现在但是打卡志愿者我都认识真的哈哈哈哈哈哈哈哈哈哈哈。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值