scanf(“%s“)真的只开读入字符串大小就可以了吗??

文章目录

  • 前言
  • 还原过程
  • 计算机程序背后的故事
  • 总结瞎逼逼

在这里插入图片描述

前言

艹艹艹艹艹艹!!!!!!!老子没想到没想到,靠!
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
本人刚刚在做树链剖分“染色”一题的代码重构,上午打爆了是在调不出来,只能从头来过
染色
bb一句:对于数据结构这种题,一旦打完后一到两个小时之内静态,动态查错都没有调出来
就应该果断删掉重构代码,重新想过(更好的其实是休息一会再调才不会跳入固定思维里面)

重构完后,我发现自己一遍过样例!!
在这里插入图片描述
但是就发现了贼nm离谱的运行,人直接给我整傻掉
在这里插入图片描述

还原过程

先看看错误代码把…
博主把该有的操作和答案操作都去掉了,让我们直接来欣赏这份代码大礼包

友情提示:该题目的操作是Q或者C只有一个字符哦

char opt[1]; int a, b, c;
for( int i = 1;i <= m;i ++ ) {scanf( "%s %d %d", opt, &a, &b );if( opt[0] == 'C' )scanf( "%d", &c );
}

看着是不是完美无瑕的亚子?!!!
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
别急着往下翻,再想想
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
你觉得这份代码没问题吧?
.
.
.
.
.
.
.
.
.
.
.
.
.
.
真的没有问题吗?
.
.
.
.
.
.
.
.
.
.
.
.
.
有的吧?
.
.
.
.
.
.
.
.
.
.
.
.
.
.
你发现了吗?!!
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
你怀疑自己之前的想法了吗?你还坚信是对的吗?
.
.
.
.
.
.
.
.
.
.
.
.
.
尽管一瞬的怀疑,可你马上否定,仍觉得这份代码没错的,对吧?
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
你开始产生怀疑了?
.
.
.
.
.
.
.
.
.
.
.
.
越来越怀疑
.
.
.
.
.
.
.
.
.
.
.
.
你越发觉得代码有点问题了?
.
.
.
.
.
.
.
.
.
.
.
可究竟错哪儿了?
.
.
.
.
.
.
.
.
.
.
.
.
冥冥之中,直觉开始作祟,有问题,却说不上来在哪?
.
.
.
.
.
.
.
.
.
.
.
.
代码错误的原因究竟是?
.
.
.
.
.
.
.
.
.
.
.
.
.
想不到
.
.
.
.
.
.
.
.
.
.
.
.
开始猜测各种情况
.
.
.
.
.
.
.
.
.
.
.
慢慢的,发现了一个比较靠谱的猜测
.
.
.
.
.
.
.
.
.
.
.
.
.
越发相信自己的猜测
.
.
.
.
.
.
.
.
.
.
.
.
现在怎么看,这份代码都有错了
.
.
.
.
.
.
.
.
.
.
.
.
坚持你的想法吗?你的想法是不是问题所在?
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
盲点,你发现了华生!!!

但!!!!!!!!!
准确来说,这份代码错了又没错
在这里插入图片描述
上图甩!走你┏ (゜ω゜)=☞
且看傻逼博主一步一步搞蒙自己
.
.
.

在这里插入图片描述
没错运行程序表明,死循环了。
死循环了???
死循环了!!!
怎么可能?!!
在这里插入图片描述
我想:换种写法试试,爷还不信了?
在这里插入图片描述
又好了???
在这里插入图片描述
结果显而易见了,肯定是forforfor循环的iii出问题了,
但是爷仔细一看,没啥啊,这不正常进行的吗,每个操作都被读入了
按道理iii应该老老实实的++++++,可为何迟迟不到mmm

早已掌握了分布调试诀窍的我马上开始printfprintfprintf分步康康
在这里插入图片描述
在这里插入图片描述
iii为什么一直等于111!!!!
在这里插入图片描述
情况一出现凭借多年踩雷从未避开过的经验,我立马感知到可能是%s\%s%s字符串劈里啪啦一堆猫病,并竟平时没少在那一块因为输入的多个空格多个换行栽跟头

但是以为这点小知识还是有的爷简单分析一波,%s\%s%s输入字符串,遇到空格换行就停,不会读入空格换行,数组从000下标开始,是前闭后开[0,1)[0,1)[0,1),一个字符装进去刚刚好啊

这种玄学RE,还是应该请教一下身边的621同学,她刚开始看到我对她一步步演示也是一个吃惊,可后来马上夺过我的键盘,先看变量定义是否用了iii,再用jjj来替换了一下iii,发现仍是这样

在一旁思考了小会儿,倏地进行了一个修改

char opt[15];

在这里插入图片描述
程序成功结束,果然是字符串这方面的问题,意料之中,但是optoptopt数组的大小却让我意料之外
接着,我马上缩小数组范围,继续观察

在这里插入图片描述
在这里插入图片描述
原来222都能接受,也就是说必须至少要开字符串长度大小+1+1+1

可这是为什么?为什么!

在这里插入图片描述

因为换行,空格这些都会对字符串造成一定影响,所以我先猜测可不可能是%s\%s%s后面的那个空格对输入造成了影响,话不多说,立马实践
在这里插入图片描述
很不幸,实践表明,后面的空格并没有对它产生任何影响
在这里插入图片描述
那么就只剩下一种可能了
尽管不可思议
却仍然可能
真是让人难以置信
在这里插入图片描述

计算机程序背后的故事

没错!就是,只能是,也必须是,输入一行后的换行对字符串造成了影响

可其实不然,这个表述有点歧义

因为字符串的确正确输入了,没有多的空格和换行

那换行怎么造成了影响?

因为!

换行符被变量iii“吸收”
!!
不可思议吧

可似乎只有这样才能解释,为什么iii迟迟不++++++,而输入的操作能正确执行

在这里插入图片描述
在这里插入图片描述

实践再次证实了我的想法

换行符真的被iii读进去了

在这里插入图片描述在这里插入图片描述
最后我得出我的想法,与君共享
.
.
.
.
.
.
.
因为optoptopt只开到了[1][1][1],所以相当于只申请了000这个空间,用于储存输入操作字符QQQ或者CCC
也就意味着没有申请多余的空间给之前先读到的换行符
那么它就只能漂泊在外
但是这偌大的空间它不可能找不到位置放下自己
所以它随意乱跳看上了变量iii,私自占有了iii,将自己的值000(ASCII码)赋给了iii
从而导致了iii的死循环

但是为什么偏偏是iii呢?系统独特设定?
我觉得不然,可能只是这份代码在这台电脑上的运行是赋值到iii
万一在其它地方,它又可以赋值到a,b,ca,b,ca,b,c甚至是其他变量
此时就算换行符赋值了,后面的输入操作也会覆盖掉,并不对结果造成干扰
所以可能本地跑RE,交上去万一AC了呢

.
.
.
.
.

当然这些都是只是拙见,毕竟我还是个小蒟蒻

总结瞎逼逼

感觉一步一步过来就像完成了一个简略的科学探究应该有的步骤

发现问题

寻找问题源头

合理分析

提出猜想

实践证明

总结归纳

虽然目前我也不造这个想法对不对
在这里插入图片描述
计算机真的很神奇呢,里面有很多自己的小规则,这种看似玄学的背后竟然是


.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
.
还是玄学
在这里插入图片描述
我要是有什么错误,欢迎指出,非常感谢能得到各位dalao的指导

别口口马我
在这里插入图片描述

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

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

相关文章

P5299-[PKUWC2018]Slay the Spire【dp】

前言 正题 题目链接:https://www.luogu.com.cn/problem/P5299 题目大意 有2n2n2n张牌&#xff0c; nnn张强化牌&#xff0c;每张上有一个正整数x(x>1)x(x>1)x(x>1)&#xff0c;如果使用后之后的每一张攻击牌伤害都会乘上xxx。nnn张攻击牌&#xff0c;每张上有一个正…

CF1152F Neko Rules the Catniverse(状压 DP)

CF1152F Neko Rules the Catniverse 给定参数 \(n,k,m\)&#xff0c;你需要求有多少个大小为 \(k\) 的序列 \(a\) 满足如下三个条件&#xff1a; 任意两个元素其权值不同。对于任意 \(i\) 满足 \(1\le i\le k\) 有 \(1\le a_i\le n\)。对于任意 \(i\) 满足 \(2\le i\le k\) 有 …

asp.net core2.2 多用户验证和授权

asp.net core2.2 用户验证 和授权有很详细和特贴心的介绍&#xff0c;我感兴趣的主要是这两篇&#xff1a;cookie身份验证基于角色的授权我的项目有两类用户&#xff1a;微信公众号用户&#xff0c;用户名为公众号的openid企业微信的用户&#xff0c;用户名为企业微信的userid每…

P1494 [国家集训队]小Z的袜子

P1494 [国家集训队]小Z的袜子 题意&#xff1a; 有一个长度为 n 的序列c[i] 。现在给出 m个询问&#xff0c;每次给出两个数l,r &#xff0c;从编号在 l 到 r 之间的数中随机选出两个不同的数&#xff0c;求两个数相等的概率。 题解&#xff1a; 很明显&#xff0c;莫队算法…

CSP2020洛谷P7076:动物园(位运算)

你知道它很水&#xff0c;但你就是切不掉它 解析 一直卡85&#xff01;&#xff01; 原因&#xff1a;最后判断的循环应该从0到k-1而不是从1到k&#xff01; 啊啊啊一定要小心啊qwq 说实话这个分都算是好的&#xff0c;这种bug爆大分一点招没有 还有一个问题是对于ans64爆unsi…

一文带你快速读懂.NET CLI

dotnet cli 是 .Net Core 功能中最有用的特性之一。在这篇文章里&#xff0c;我们将介绍几个.Net OSS 工具是如何使用 dotnet cli&#xff0c;并介绍如何在日常开发中使用新的 cli 工具。正文关键要点dotnet cli 使得基于. Net 项目的自动化和脚本编写变得非常简单&#xff0c;…

[POJ 3164]Command Network(最小树形图,朱刘算法)

文章目录titlesolutioncodetitle solution 读完翻译后&#xff0c;很明显就是个朱刘算法的板子题 最小树形图&#xff0c;就是给出一个带权有向图 从中指定一个特殊的结点 root 求一棵以 root 为根的有向生成树 T&#xff0c;且使得 T 中所有边权值最小 简单来说&#xff0c…

CF1553H-XOR and Distance【dp】

正题 题目链接:https://www.luogu.com.cn/problem/CF1553H 题目大意 给出nnn个在[0,2n)[0,2^n)[0,2n)范围内的数字序列aaa。 对于每个x∈[0,2n)x\in[0,2^n)x∈[0,2n)求 min⁡i≠j∣aixorx−ajxorx∣\min_{i\neq j}\ |a_i\ xor\ x-a_j\ xor\ x|i​jmin​ ∣ai​ xor x−aj​…

同余最短路

主要内容 形如&#xff1a; 设问 \(1\) &#xff1a;给定 \(n\) 个整数&#xff0c;求这 \(n\) 个整数在 \(h(h\le2^{63}-1)\) 范围内 能拼凑出多少的其他整数( 个整数可以重复取) 。 设问 \(2\) &#xff1a;给定 \(n\) 个整数&#xff0c;求这 \(n\) 个整数 不能拼凑出的最小…

SP10707 COT2 - Count on a tree II

SP10707 COT2 - Count on a tree II 题意&#xff1a; 给定 n 个结点的树&#xff0c;每个结点有一种颜色。 m 次询问&#xff0c;每次询问给出 u,v&#xff0c;回答 u,v 之间的路径上的结点的不同颜色数。 1< n < 4*10^4 1< m < 10^5 题解&#xff1a; 树上…

[CQOI2018]异或序列

[CQOI2018]异或序列 题意&#xff1a; 给定1个整数K&#xff0c;离线询问[l,r]中有多少子区间xor和K。 题解&#xff1a; 异或有个重要的性质&#xff1a;它的逆运算就是自身 我们维护该数列的前缀异或和a[x],表示1到x的区间异或和&#xff0c;这样问题就变成了在区间[l-1,…

ASP.NET Core 3.0:将会拥有更少的依赖

在ASP.NET Core项目中&#xff0c;我们使用一个叫做Microsoft.AspNetCore.App的综合包。它也被称为ASP.NET Core Shared Framework&#xff0c;在ASP.NET Core Shared Framework之中包含了很多依赖项&#xff0c;它能满足一般应用的需求。但是如果你查看它的依赖项&#xff0c;…

CSP2020洛谷P7077:函数调用

解析 没做出来… qwq 自己只能想到拓扑开vector把每个函数搞成一个奇怪的加法标记和乘法标记的结合 极限数据卡一卡还是nm的 得分纯玄学qwq 本题的关键是乘法相当于把函数调用多次 这样就可以利用和全是加法类似的策略拓扑统计每个函数的调用次数 使问题得以解决 要注意部分…

CF1616H Keep XOR Low(Trie 树上 DP)

CF1616H Keep XOR Low 给你 \(n\) 个整数 \(a_1,a_2,\cdots,a_n\) 和一个整数 \(x\)。 你需要求出 \(\{1,2,\cdots,n\}\) 的一个子集 \(S\)&#xff0c;满足 \(S\) 中任意两个不同的元素 \(i,j\)&#xff0c;满足 \(a_i~{\rm xor}~a_j\le x\)。 求选取 \(S\) 的方案数&#xff…

[UVA - 11865]Stream My Contest(最小树形图+朱刘算法)

本题过于简单&#xff0c;朱刘算法模板题&#xff0c;考虑二分一下带宽即可titlecodetitle code #include <cstdio> #include <cstring> #include <iostream> using namespace std; #define MAXN 65 #define MAXM 100005 #define int long long #define in…

CSP2021NOIP2021游记

CSP Day -? 初赛 初赛考前没怎么复习&#xff0c;反倒是理直气壮的翘了一周晚修&#xff08;虽然后面就一直翘了&#xff09;。 开考之后才发现要拿那几张纸&#xff0c;监考让我考完再出去拿。 选择题很简单&#xff0c;没有啥犹豫的写完了&#xff0c;第一道读程序写结果好…

P3226 [HNOI2012]集合选数(状压 DP)

P3226 [HNOI2012]集合选数 要求选出集合 \(S\) 满足如果 \(x\) 选择了&#xff0c;\(2x\) 和 \(3x\) 都不能选择。 求 \(\{1,2,\dots,n\}\) 的符合要求的子集数量。 \(n\le 10^5\)。 发现对所有除去 \(2,3\) 因子后不同的数&#xff0c;他们之间没有关联&#xff0c;完全可以分…

微软上线Try .NET,支持在浏览器运行C#代码

微软Try .NET项目近期上线&#xff0c;这一项目允许用户通过浏览器运行和编写C#代码&#xff0c;同时还支持完整的代码提示。用户可以通过访问这一项目官网&#xff08;点此进入&#xff09;对Try .NET这一项目进行简单了解。该项目允许开发人员在浏览器中运行和编辑C#代码片段…

第46届ICPC亚洲区域赛(沈阳)L-Perfect Matchings【dp,组合数学】

正题 题目链接:https://ac.nowcoder.com/acm/contest/24346/L 题目大意 有一张2n2n2n个点的完全图&#xff0c;在上面删除一棵生成树&#xff0c;然后求这张图的完全匹配方案数。 1≤n≤20001\leq n\leq 20001≤n≤2000 解题思路 考虑容斥&#xff0c;可以dpdpdp出fi,j,0/1f…

CSP2019洛谷P5666:树的重心

解析 毒题 细节有亿点点多 我一开始的思路是没有问题的 尝试统计有多少种方案能砍出大小在一个区间的子树、 当时的想法是线段树合并 但是这个玩意在需要保留原树的情况下空间复杂度炸没了… 因为我垃圾的实现一个dfs里面就玩了七遍merge函数… 空间常数飞起 然后分数就和暴力…