1、输入两个字符串a,b;把a中包括b中的字符过滤后输出:
输入:'abcad'
'ac'
输出:'bd'
参考代码:
void result_int(string str1,string str2)
{
int count[26] = {0};
for(int i=0; str2[i] != '\0';i++)
{
char temp = str2[i] - 'a';
count[temp]++;
}
for(int i=0; str1[i] != '\0';i++)
{
char temp = str1[i] - 'a';
if(count[temp] == 0)
cout<<str1[i];
}
return;
}
{
int count[26] = {0};
for(int i=0; str2[i] != '\0';i++)
{
char temp = str2[i] - 'a';
count[temp]++;
}
for(int i=0; str1[i] != '\0';i++)
{
char temp = str1[i] - 'a';
if(count[temp] == 0)
cout<<str1[i];
}
return;
}
2、输入一个数字,得到它的二进制形式,再左右变换后,输出新的十进制值(32位机)
输入:25
输出:2550136832
参考代码:
long long BinV(int& N)
{
int binValue[32] = {0};
long long temp = N;
long long num;
int i = 0;
while( temp != 0)
{
num = temp%2;
binValue[i] = num;
i++;
temp = temp/2;
}
long long sum = 0;
for(i=31;i>=0;i--)
{
sum += (long long)(pow(2.0,i)*binValue[31-i]);
}
return sum;
}