5 345 mul 122 3945 div 12 321 add 343 340 sub 211 377 mod 27
42090 328 664 129 26
计算概论05
strcmp:
strcmp(字符串名1,字符串名2):比较字符串1和字符串2的大小,比较的结果由函数带回;
1. 如果字符串1>字符串2,返回一个正整数;
2. 如果字符串1=字符串2,返回0;
3. 如果字符串1<字符串2,返回一个负整数。
实际上,字符串的比较是比较字符串中各对字符的ASCII码。首先比较两个串的第一个字符,若不相等,则停止比较并得出大于或小于的结果;如果相等就接着 比较第二个字符然后第三个字符等等。如果两上字符串前面的字符一直相等,像"disk"和"disks" 那样, 前四个字符都一样, 然后比较第 五个字符, 前一个字符串"disk"只剩下结束符'/0',后一个字符串"disks"剩下's','/0'的ASCII码小于's'的ASCII 码,所以得出了结果。因此无论两个字符串是什么样,strcmp函数最多比较到其中一个字符串遇到结束符'/0'为止,就能得出结果。
注意:字符串是数组类型而非简单类型,不能用关系运算进行大小比较。
if("ABC">"DEF") /*错误的字符串比较*/
if(strcmp("ABC","DEF") /*正确的字符串比较*/
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
char s[7];
int main()
{
int a,b,n;
cin>>n;
while(n--)
{
cin>>a>>s>>b;
if(strcmp(s,"add")==0) printf("%d\n",a+b);
if(strcmp(s,"sub")==0) printf("%d\n",a-b);
if(strcmp(s,"mul")==0) printf("%d\n",a*b);
if(strcmp(s,"div")==0) printf("%d\n",a/b);
if(strcmp(s,"mod")==0) printf("%d\n",a%b);
}
return 0;
}