visual studio 2015简直是放飞自我,亲近菜鸟。c++里printf(),scanf()通用,动态数组还能随时手动赋值,代码写的没有你做不到,只有你想不到,换个编译器就谁都不认了。
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
void PrintInt(vector<int> a) {
for (int i = 0; i < a.size(); i++) {
if (i == a.size() - 1)
printf("%d\n", a[i]);
else printf("%d ", a[i]);
}
}
void TypeInt() {
vector<int>a(5, 1);
vector<int>::iterator iter;//vector中int类型的迭代量
vector<int>::iterator begin = a.begin();//a.begin()。a.end()属于迭代量
PrintInt(a);
//*************************************** 结果1 1 1 1 1
for (int i = 0; i < 3; i++) {
a.push_back(2);
}
PrintInt(a);
//*************************************** 结果1 1 1 1 1 2 2
a = { 2,5,3,66,3,5 };
sort(a.begin(), a.end());
PrintInt(a);
//***************************************
a.clear();
for (int i = 0; i < 5; i++) {
a.insert(a.begin() + i, 5);
}
a.erase(a.end()-1);//a.end()-1就相当于最后一个元素的位置
PrintInt(a);
//***************************************
int cap = a.capacity();
cout << "目前可用空间为" << cap << endl;
//其空间指的是目前所申请的最大的数量
for (int i = 0; i < 11; i++) {
a.push_back(2);
}
PrintInt(a);
cap = a.capacity();
cout << "目前可用空间为" << cap << endl;
//动态数组不能被当为一般的数组调用,它是个迭代数组
a = { 1,3,3,3,3,1 };
a.insert(a.begin()+3, 5);
cap = a.at(3);//vector.at(index) 表示传回索引所指的数据
int cap2 = a.front();//返回第一个数据
int cap3 = a.back();//返回最后一个数据
PrintInt(a);
cout << cap <<'\t'<<cap2<<'\t'<<cap3<< endl;
}
void PrintStr(vector<char*> str) {
for (int i = 0; i < str.size(); i++) {
if (i == str.size() - 1)
printf("%s\n", str[i]);
else printf("%s ", str[i]);
}
}
void Typechar() {
vector<char*>str(5, "abc");
PrintStr(str);
}
int main() {
TypeInt();
printf("按回车键进入字符串测试");
getchar();
system("cls");
Typechar();
return 0;
}