Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 22 additions & 13 deletions 1.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,39 +2,48 @@
using namespace std;

class container {

protected:
int size;
public:
float* p;
container(int s) :size(s){}
const int& getsize() { return size;}

container(int s) :size(s) {}
const int& getsize()const { return size; }
int& getsize() {
return size;
}
};

class vector :public container {

int len;
int call_num;
public:
explicit vector(int l) :len(l),size(1 * 100){
explicit vector(int l) :len(l), container(1 * 100) {
p = new float();
}
int len;
int& getlen() const {
call_num ++;
vector(container obj) :len(0),container(obj.getsize()){
p = new float();
}
const int& getlen() const {
return len;
}
int& getlen() {
call_num++;
return len;
}
~vector() = default;
~vector() {
delete p;
}
};

int main() {

container c1(100);
vector v1 = c1;
vector v1 =c1;
container& r1 = v1;
container c2 = 100;
c2.getsize() = 20;
cout << c2.getsize();
vector v2 = 100;
v2.getlen = 40;
vector v2 = (vector)100;
v2.getlen() = 40;
cout << v2.getlen();
}
8 changes: 4 additions & 4 deletions 2.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,11 @@ using namespace std;

// count all the specific char in the whole array of strings
int countAllSpecificChars(string sArr[], int arrLength, char specificChar) {
int count;
for (int i = 0; i <= arrLength; ++i)
for (int j = 0; j <= sArr[i].size(); ++j)
int count=0;
for (int i = 0; i < arrLength; ++i)
for (int j = 0; j <sArr[i].size(); ++j)
// if the jth char of the string is the specific char
if (sArr[i][j] = specificChar)
if (sArr[i][j] == specificChar)
count++;
return count;
}
Expand Down
74 changes: 50 additions & 24 deletions 3.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,22 +2,26 @@
#include<stdlib.h>
#define MAX_SIZE 200
int arr[MAX_SIZE];

#pragma warning (disable:4996)
typedef struct alfa * alfaptr;

struct alfa {
long long x;
alfaptr next;
};
alfaptr rear = NULL, front = NULL;
void push(int x)
{
void push(int x) {
alfaptr node;
node = (alfaptr)malloc(sizeof(struct alfa));
node->x = x;
node->next = NULL;
if (!front)
{
front = node;
else {
rear = node;
}
else
{
rear->next = node;
rear = node;
}
Expand All @@ -30,65 +34,84 @@ void pop()
printf("ERROR1");
else
{
node = front->next;
front = node;
node = front;
front = front->next;
free(node);
}
}
void search(int x)
{
alfaptr node = front;
int counter = 0;
while (node)
if (node->x == x)
while (node) {
if (node->x == x) {
printf("%d", counter);
else {
printf("ERROR2");
break;
return;
}
node = node->next;
counter++;
}
printf("ERROR2");
}

void rpop() {//pop last element
alfaptr node = front;
while (node)
node = node->next;
free(rear);
rear = node;
if (!front)
printf("ERROR1");
else if (front == rear) { // there is only one element in the list
free(front);
front = NULL;
rear = NULL;
}
else {
while (node->next != rear) {
node = node->next;
}
node->next = NULL;
free(rear);
rear = node;
}
}

void set()
{
void set(){
alfaptr node = front;
for (int i = 0; i < MAX_SIZE && node; i++, node = node->next)
arr[i] = node->x;
}

int size()
{
alfaptr node = front;
int count;
while (node)
count++;node = node->next;
int count = 0;
while (node) {
count++;
node = node->next;
}
return count;
}

void show()
{
if (!front) {
for (int i = 0; i < MAX_SIZE; i++)
for (int i = 0; i < MAX_SIZE&&arr[i]!=0; i++)
printf("%d ", arr[i]);
printf("\n");
}
else
{
printf("ERROR3");
alfaptr node = front;
while (node) {
printf("%lld ", node->x);
node = node->next;
}
printf("\n");
}
}

int average()
{

alfaptr node = front;
int sum = 0, count;
int sum = 0, count=0;
while (node) {
sum += node->x;
count++;
Expand Down Expand Up @@ -129,6 +152,9 @@ void main()
case 7://size
printf("%d", size());
break;
case 8:
printf("%d", average());
break;
case 10:
exit(0);
}
Expand Down
7 changes: 4 additions & 3 deletions 4.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,8 +2,9 @@
int main()
{
float arr[5] = { 12.5, 10.0, 13.5, 90.5, 0.5 };
float *ptr1 = &arr[0];
float *ptr2 = ptr1 + 3;
float* ptr1 = &arr[0];
float* ptr2 = ptr1 + 3;
printf("%f", *ptr2 - *ptr1);
return 0;
}
}
//output:78.000000
8 changes: 5 additions & 3 deletions 5.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,11 @@
int main()
{
int arr[] = { 10, 20, 30, 40, 50, 60 };
int *ptr1 = arr;
int *ptr2 = arr + 5;
int* ptr1 = arr;
int* ptr2 = arr + 5;
printf("%d\n", (*ptr2 - *ptr1));
printf("%c", (char)(*ptr2 - *ptr1));
return 0;
}
}
//output://50
//2
15 changes: 8 additions & 7 deletions 6.cpp
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
#include<stdio.h>
int main()
{
int a;
char *x;
x = (char *)&a;
a = 512;
x[0] = 1;
printf("%d\n", a);
return 0;
int a;
char* x;
x = (char*)&a;
a = 512;
x[0] = 1;
printf("%d\n", a);
return 0;
}
//output:513
7 changes: 4 additions & 3 deletions 7.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -2,9 +2,10 @@
int main()
{
int arr[] = { 1, 2, 3, 4, 5 };
int *p = arr;
++*p;
int* p = arr;
++* p;
p += 2;
printf("%d", *p);
return 0;
}
}
//3
7 changes: 4 additions & 3 deletions 8.cpp
Original file line number Diff line number Diff line change
@@ -1,13 +1,14 @@
#include<stdio.h>
const char * f(const char **p) {
const char* f(const char** p) {
auto q = (p + sizeof(char))[1];
return q;
}
int main() {
const char * str[] = { "Wish","You","Best",":D" };
const char* str[] = { "Wish","You","Best",":D" };
printf("%c%c ", *f(str), *(f(str) + 1));
printf("%c%c%c%c\n", **str, *(*(str + 1) + 1), *((str + 2)[-1] + 1), **&*(&str[-1] + 1));



}
//output:Be WooW