3、C++|day3

本文探讨了字符计数的不同编程方法,涉及输入字符计数的正确实现,常量指针与常量引用的区别,以及针对小端架构的内存布局理解。通过实例展示了如何统计字符数量、指针操作的技巧,并解析了一个32位小端机器上的内存输出结果。
摘要由CSDN通过智能技术生成

一、选择

1.设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是(D)
A n=0;while(ch=getchar()!=‘\n’)n++;
B n=0;while(getchar()!=‘\n’)n++;
C for(n=0;getchar()!=‘\n’;n++);
D n=0;for(ch=getchar();ch!=‘\n’;n++);
解析:
2.下面3段程序代码的效果一样吗()
int b;
(1)const int *a = &b;
(2)int const *a = &b;
(3)int *const a = &b;
A (2)=(3)
B (1)=(3)
C (1)=(2)
D 都不一样
D (错误)
正确答案: C
解析:
3.假设在一个 32 位 little endian 的机器上运行下面的程序,结果是多少?
#include <stdio.h>
int main() {
long long a = 1, b = 2, c = 3;
printf(“%d %d %d\n”, a, b, c);
return 0;
}
A 1,2,3
B 1,0,2
C 1,3,2
D 3,2,1
A (错误)
正确答案: B
解析:

二、编程

1.最长数字子串

链接:最长数字子串
思路:一个本串,一个比较串,一个结果,比较串累加,最后得出结果。

#include <iostream>
using namespace std;
int main() {
    string str, cur, res;
    cin >> str;
    for(int i = 0; i <= str.size(); i++)
    {
        if(str[i] >= '0' && str[i] <= '9') {
            cur += str[i];
        }
        else {
        if(res.size() < cur.size()) 
        res = cur; 
        else
        cur.clear();
        }
    }
    cout << res << endl;
}
// 64 位输出请用 printf("%lld")
2.出现一半以上的数字

链接:出现一半以上的数字

方法1:
但由于涉及到快排sort,其时间复杂度为O(NlogN)并非最优;
class Solution {
public:
    int MoreThanHalfNum_Solution(vector<int> numbers) 
    {
           sort(numbers.begin(),numbers.end());
           return numbers[numbers.size() / 2];
    }
};
方法2:
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值