之前作业的更改
This commit is contained in:
parent
4bc9f9ccd8
commit
2ce164a667
5 changed files with 308 additions and 11 deletions
|
@ -26,7 +26,8 @@ void swap(int *a, int *b)
|
||||||
void bobblesort1A(int a[], int n)
|
void bobblesort1A(int a[], int n)
|
||||||
{
|
{
|
||||||
bool sorted = false;
|
bool sorted = false;
|
||||||
A:
|
while (sorted == false)
|
||||||
|
{
|
||||||
sorted = true;
|
sorted = true;
|
||||||
|
|
||||||
for (int i = 1; i < n; i++)
|
for (int i = 1; i < n; i++)
|
||||||
|
@ -39,8 +40,7 @@ A:
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
n--;
|
n--;
|
||||||
if (sorted == false)
|
}
|
||||||
goto A;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void bobblesort1B(int a[], int n)
|
void bobblesort1B(int a[], int n)
|
||||||
|
|
|
@ -27,6 +27,7 @@ int main()
|
||||||
case 1:
|
case 1:
|
||||||
printf("输入待插入数值\n");
|
printf("输入待插入数值\n");
|
||||||
scanf("%d", &temp[0]);
|
scanf("%d", &temp[0]);
|
||||||
|
printf("插入秩为%d处\n",v.search(temp[0]) + 1);
|
||||||
(v.insert(v.search(temp[0]) + 1, temp[0]) != -1) ? (printf("输出数组\n")) : (printf("无此元素或超出范围\n"));
|
(v.insert(v.search(temp[0]) + 1, temp[0]) != -1) ? (printf("输出数组\n")) : (printf("无此元素或超出范围\n"));
|
||||||
v.printall();
|
v.printall();
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -194,6 +194,8 @@ void Vec::mergeSort(int lo, int hi)
|
||||||
mergeSort(lo, mi);
|
mergeSort(lo, mi);
|
||||||
mergeSort(mi + 1, hi);
|
mergeSort(mi + 1, hi);
|
||||||
merge(lo, mi, hi);
|
merge(lo, mi, hi);
|
||||||
|
|
||||||
|
_sorted = true;
|
||||||
}
|
}
|
||||||
int Vec::search(int e)
|
int Vec::search(int e)
|
||||||
{
|
{
|
||||||
|
|
238
ex4/vec.cpp
Normal file
238
ex4/vec.cpp
Normal file
|
@ -0,0 +1,238 @@
|
||||||
|
#include "vec.h"
|
||||||
|
|
||||||
|
Vec::Vec(int len, int mode)
|
||||||
|
{
|
||||||
|
_used = len - 1;
|
||||||
|
_len = len * 2;
|
||||||
|
_v = new int[_len];
|
||||||
|
|
||||||
|
// for (int i = 0; i <= _used; i++)
|
||||||
|
// _v[i] = i + 1;
|
||||||
|
if (mode == 1)
|
||||||
|
{
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
_v[i] = rand() % (2 * (_used + 1));
|
||||||
|
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
swap(i, rand() % (2 * (_used + 1)));
|
||||||
|
}
|
||||||
|
else if (mode == 2)
|
||||||
|
{
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
_v[i] = _used - i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int Vec::get(int a)
|
||||||
|
{
|
||||||
|
return _v[a];
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::put(int a, int value)
|
||||||
|
{
|
||||||
|
_v[a] = value;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::swap(int a, int b)
|
||||||
|
{
|
||||||
|
int temp = _v[a];
|
||||||
|
_v[a] = _v[b];
|
||||||
|
_v[b] = temp;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::expand()
|
||||||
|
{
|
||||||
|
_len = _len * 2;
|
||||||
|
int *p = new int[_len];
|
||||||
|
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
p[i] = _v[i];
|
||||||
|
|
||||||
|
delete[] _v;
|
||||||
|
_v = p;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::shrink()
|
||||||
|
{
|
||||||
|
if (((double)_used / (double)_len) >= 0.25)
|
||||||
|
return;
|
||||||
|
|
||||||
|
_len = _len >> 1;
|
||||||
|
int *p = new int[_len];
|
||||||
|
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
p[i] = _v[i];
|
||||||
|
|
||||||
|
delete[] _v;
|
||||||
|
_v = p;
|
||||||
|
}
|
||||||
|
//位置 数值
|
||||||
|
int Vec::insert(int locate, int value)
|
||||||
|
{
|
||||||
|
if (locate == _used + 1)
|
||||||
|
{
|
||||||
|
_used++;
|
||||||
|
_v[_used] = value;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (locate < 0 || locate > _used)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
_used++;
|
||||||
|
|
||||||
|
if (_used >= _len)
|
||||||
|
expand();
|
||||||
|
|
||||||
|
for (int i = _used; i > locate; i--)
|
||||||
|
_v[i] = _v[i - 1];
|
||||||
|
|
||||||
|
_v[locate] = value;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
//位置 删除个数
|
||||||
|
int Vec::remove(int locate, int value)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (locate < 0 || ((_used - value) < 0) || ((locate + value - 1) > _used))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
_used = _used - value;
|
||||||
|
|
||||||
|
for (int i = locate; i <= _used; i++)
|
||||||
|
_v[i] = _v[i + value];
|
||||||
|
|
||||||
|
shrink();
|
||||||
|
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
|
||||||
|
//删除某一元素
|
||||||
|
int Vec::remove_sorted(int value)
|
||||||
|
{
|
||||||
|
int j, i;
|
||||||
|
|
||||||
|
for (i = 0; i <= _used && _v[i] != value; i++)
|
||||||
|
;
|
||||||
|
|
||||||
|
for (j = 1; _v[i + j] == value; j++)
|
||||||
|
;
|
||||||
|
|
||||||
|
return remove(i, j);
|
||||||
|
}
|
||||||
|
|
||||||
|
int Vec::count(int value)
|
||||||
|
{
|
||||||
|
int j, i;
|
||||||
|
|
||||||
|
for (i = 0; i <= _used && _v[i] != value; i++)
|
||||||
|
;
|
||||||
|
|
||||||
|
for (j = 0; _v[i + j] == value && i + j <= _used; j++)
|
||||||
|
;
|
||||||
|
|
||||||
|
if (j == 0)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
return j;
|
||||||
|
}
|
||||||
|
|
||||||
|
int Vec::find(int value)
|
||||||
|
{
|
||||||
|
int i = 0;
|
||||||
|
for (i; i <= _used; i++)
|
||||||
|
{
|
||||||
|
if (_v[i] == value)
|
||||||
|
{
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int Vec::getlen()
|
||||||
|
{
|
||||||
|
return _len;
|
||||||
|
}
|
||||||
|
|
||||||
|
int Vec::getused()
|
||||||
|
{
|
||||||
|
return _used;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::printall()
|
||||||
|
{
|
||||||
|
for (int i = 0; i <= _used; i++)
|
||||||
|
printf("%d\n", _v[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::bubbleSort()
|
||||||
|
{
|
||||||
|
int n = _used;
|
||||||
|
bool sorted = false;
|
||||||
|
|
||||||
|
while (!sorted)
|
||||||
|
{
|
||||||
|
sorted = true;
|
||||||
|
|
||||||
|
for (int i = 1; i <= n; i++)
|
||||||
|
{
|
||||||
|
if (_v[i - 1] > _v[i])
|
||||||
|
{
|
||||||
|
swap(i - 1, i);
|
||||||
|
|
||||||
|
sorted = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
n--;
|
||||||
|
}
|
||||||
|
_sorted = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::mergeSort(int lo, int hi)
|
||||||
|
{
|
||||||
|
if (lo >= hi)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
int mi = lo + (hi - lo) / 2;
|
||||||
|
mergeSort(lo, mi);
|
||||||
|
mergeSort(mi + 1, hi);
|
||||||
|
merge(lo, mi, hi);
|
||||||
|
|
||||||
|
_sorted = true;
|
||||||
|
}
|
||||||
|
int Vec::search(int e)
|
||||||
|
{
|
||||||
|
if (_sorted == false)
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
int i = 0;
|
||||||
|
for (i; i <= _used && _v[i] <= e; i++)
|
||||||
|
;
|
||||||
|
|
||||||
|
return i - 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Vec::merge(int lo, int mi, int hi)
|
||||||
|
{
|
||||||
|
|
||||||
|
int i = lo, j = mi + 1, k = 0;
|
||||||
|
int *temp = new int[hi - lo + 1];
|
||||||
|
while (i <= mi && j <= hi)
|
||||||
|
{
|
||||||
|
if (_v[i] <= _v[j])
|
||||||
|
temp[k++] = _v[i++];
|
||||||
|
else
|
||||||
|
temp[k++] = _v[j++];
|
||||||
|
}
|
||||||
|
while (i <= mi)
|
||||||
|
temp[k++] = _v[i++];
|
||||||
|
while (j <= hi)
|
||||||
|
temp[k++] = _v[j++];
|
||||||
|
for (i = lo, k = 0; i <= hi; i++, k++)
|
||||||
|
_v[i] = temp[k];
|
||||||
|
delete[] temp;
|
||||||
|
}
|
56
ex4/vec.h
Normal file
56
ex4/vec.h
Normal file
|
@ -0,0 +1,56 @@
|
||||||
|
#ifndef _INC_STDIO
|
||||||
|
#include <stdio.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef _GLIBCXX_STDLIB_H
|
||||||
|
#include <stdlib.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
class Vec
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
int *_v;
|
||||||
|
int _len;
|
||||||
|
int _used;
|
||||||
|
bool _sorted = false;
|
||||||
|
|
||||||
|
void expand();
|
||||||
|
|
||||||
|
void shrink();
|
||||||
|
|
||||||
|
public:
|
||||||
|
Vec(int _len,int mode);
|
||||||
|
|
||||||
|
int get(int a);
|
||||||
|
|
||||||
|
int search(int value);
|
||||||
|
|
||||||
|
void put(int a, int value);
|
||||||
|
|
||||||
|
void swap(int a, int b);
|
||||||
|
|
||||||
|
int insert(int locate, int value);
|
||||||
|
|
||||||
|
int remove(int locate, int value);
|
||||||
|
|
||||||
|
int remove_sorted(int value);
|
||||||
|
|
||||||
|
int find(int value);
|
||||||
|
|
||||||
|
void bubbleSort();
|
||||||
|
|
||||||
|
void printall();
|
||||||
|
|
||||||
|
int getlen();
|
||||||
|
|
||||||
|
int getused();
|
||||||
|
|
||||||
|
int count(int value);
|
||||||
|
|
||||||
|
void mergeSort(int lo, int hi);
|
||||||
|
|
||||||
|
private:
|
||||||
|
void merge(int lo, int mi, int hi);
|
||||||
|
};
|
Reference in a new issue