- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
#include <iostream>
#include <cmath>
#include <limits.h>
#include <stdlib.h>
using namespace std ;
long long NumberHouses = 0 ;
long long ClosestHouse[2] = {0,0} ;
long long TravelTimes = 0 ;
void GetHouses(long long NumH, long long House_X[], long long House_Y[])
{
for (long long a = 0 ; a < NumH ; a++)
{
cin >> House_X[a] ;
cin >> House_Y[a] ;
}
}
void SortArray(long long NumH, long long SortedArray[], long long HouseArray[])
{
long long InsertPoint = 0 ;
for (int a = 0 ; a < NumH ; a++)
{
SortedArray[a] = LONG_MAX ;
}
for (int a = 0 ; a < NumH ; a++)
{
for (int b = 0 ; b < NumH ; b++)
{
if (HouseArray[a] < SortedArray[b])
{
InsertPoint = b ;
for (int c = NumH ; c > b ; c--)
{
SortedArray[c] = SortedArray[c-1] ;
}
SortedArray[InsertPoint] = HouseArray[a] ;
b = NumH ;
}
}
}
}
void FindMedians(long long NumH, int NumMeds, long long SortedArray[], long long MediansArray[])
{
int MedianNum = 0 ;
long long *Sorted_X = new long long [NumH] ;
long long *Sorted_Y = new long long [NumH] ;
MedianNum = NumH / 2 ;
if (NumMeds == 1)
{
MediansArray[0] = SortedArray[MedianNum] ;
}
else
{
MediansArray[0] = SortedArray[MedianNum] ;
MediansArray[1] = SortedArray[MedianNum + 1] ;
}
}
void FindMidHouse(long long NumH, int NumMeds, long long Cords_X[], long long Cords_Y[], long long Meds_X[], long long Meds_Y[])
{
long long *CloseHouses = new long long [NumH] ;
long long NumPoints = 0 ;
long long LowestMoves = LONG_MAX ;
for (int a = 0 ; a < NumH ; a++)
{
if (abs(Cords_X[a] - Meds_X[0]) > abs(Cords_X[a] - Cords_Y[0]))
{
if (abs(Cords_X[a] - Meds_X[0] <= LowestMoves))
{
LowestMoves = abs(Cords_X[a] - Meds_X[0]) ;
CloseHouses[a] = a ;
NumPoints++ ;
}
}
else
{
if (abs(Cords_Y[a] - Meds_Y[0] <= LowestMoves))
{
LowestMoves = abs(Cords_Y[a] - Meds_Y[0]) ;
CloseHouses[a] = a ;
NumPoints++ ;
}
}
}
long long *CloseHousesSums = new long long [NumH] ;
for (int a = 0 ; a < NumPoints ; a++)
{
for (int b = 0 ; b < NumH ; b++)
{
if ((abs(Cords_X[CloseHouses[a]]) - Cords_X[b]) > (abs(Cords_Y[CloseHouses[a]]) - Cords_Y[b]))
{
CloseHousesSums[a] = CloseHousesSums[a] + abs(Cords_X[CloseHouses[a]] - Cords_X[b]) ;
}
else
{
CloseHousesSums[a] = CloseHousesSums[a] + abs(Cords_Y[CloseHouses[a]] - Cords_Y[b]) ;
}
}
}
for (int a = 0 ; a < (NumPoints - 1) ; a++)
{
if (CloseHousesSums[a] < CloseHousesSums[a+1])
{
ClosestHouse[0] = Cords_X[CloseHouses[a]] ;
ClosestHouse[1] = Cords_Y[CloseHouses[a]] ;
}
}
}
void GetClosestHouse(long long NumH, long long House_X[], long long House_Y[], long long ClosestHouse[])
{
int MedianAmt = 0 ;
long long *Sorted_X = new long long [NumH] ;
long long *Sorted_Y = new long long [NumH] ;
/* long long *Sorted_1 = new long long ;//[NumH] ;
long long *Sorted_a = new long long ;//[NumH] ;
long long *Sorted_b = new long long ;//[NumH] ;
long long *Sorted_c = new long long ;//[NumH] ;
long long *Sorted_d = new long long ;//[NumH] ;
long long *Sorted_e = new long long ;//[NumH] ;
long long *Sorted_f = new long long ;//[NumH] ;*/
SortArray(NumberHouses, Sorted_X, House_X) ;
SortArray(NumberHouses, Sorted_Y, House_Y) ;
for (int a = 0 ; a < NumH ; a++)
{
cout << Sorted_X[a] << "," << Sorted_Y[a] << endl ;
}
if (NumH % 2 == 0)
{
MedianAmt = 1 ;
}
else
{
MedianAmt = 2 ;
}
cout << MedianAmt << endl ;
cout << "sun" ;
long long *Medians_X = new long long [MedianAmt] ;
long long *Medians_Y = new long long [MedianAmt] ;
cout << "shine" << endl ;
FindMedians(NumberHouses, MedianAmt, Sorted_X, Medians_X) ;
FindMedians(NumberHouses, MedianAmt, Sorted_Y, Medians_Y) ;
FindMidHouse(NumberHouses, MedianAmt, House_X, House_Y, Medians_X, Medians_Y) ;
}
void GetHouseDistances(long long NumH, long long House_X[], long long House_Y[], long long ClosestHouse[], long long& TravelTimes)
{
long long Difference_X = 0 ;
long long Difference_Y = 0 ;
for (int a = 0 ; a < NumH ; a++)
{
Difference_X = abs(ClosestHouse[0] - House_X[a]) ;
Difference_Y = abs(ClosestHouse[1] - House_Y[a]) ;
//cout << Difference_X << " - Difference_X" << endl ;
//cout << Difference_Y << " - Difference_Y" << endl ;
if (Difference_X > Difference_Y)
{
TravelTimes = TravelTimes + Difference_X ;
}
else
{
TravelTimes = TravelTimes + Difference_Y ;
}
}
//cout << TravelTimes << endl ;
}
int main()
{
cin >> NumberHouses ;
long long *House_X = new long long [NumberHouses] ; // x coordinate of houses
long long *House_Y = new long long [NumberHouses] ; // y coordinate of houses
GetHouses(NumberHouses, House_X, House_Y) ;
GetClosestHouse(NumberHouses, House_X, House_Y, ClosestHouse) ;
GetHouseDistances(NumberHouses, House_X, House_Y, ClosestHouse, TravelTimes) ;
cout << TravelTimes << endl ;
}
现在 - 你会注意到我有一个巨大的注释掉了类似创建的其他数组的代码部分 - 当我有那些未注释时我的代码工作 - 但是当我评论它们时它在输出'sun'之后但在'之前崩溃闪耀'。
我曾尝试使用其他参数来创建内存长度 - 例如 MedianAmt,这包括其他变量和实际数字。我也尝试过使用 long long 变量作为参数。
我不确定为什么它不起作用 - 如果您希望我提供有关我的代码或情况的更多信息,我会尽力回答他们 - 感谢您的帮助。
编辑:我运行可执行文件,它进入“sun”状态,然后卡住 - 它可能需要一两秒钟才会停止响应并关闭。 NuMH 可以达到 long long max amount - 64 位 我不知道我在哪里释放了任何内存 - 我是一个相对新手的程序员 - 并且没有给出错误消息。我当时认为这也是一个堆损坏问题 - 但为什么添加上面我已经注释掉的所有超长长数组会导致它不会崩溃?
我可以发布我的源代码的其余部分 - 但它有 200 行长而且可能有点乱 - 这会有用吗?
编辑 2:至于堆损坏,我将我的 IDE 和程序保存在我的闪存驱动器上 - 但试图在两台不同的计算机上运行它 - 所以我认为可以安全地假设堆没有损坏。也许指向内存的无效指针是问题所在,IDE 会影响我的指针选择内存的位置吗?
编辑 3:我在我尝试运行的两台机器上运行 Windows 7。
编辑 4:更新以获取我的完整源代码..
最佳答案
我想我在 SortArray
中至少发现了一个错误:
for (int c = NumH ; c > b ; c--)
{
SortedArray[c] = SortedArray[c-1] ;
}
假设 SortedArray
的大小为 NumH
,您在第一次迭代时就超出了数组边界。我没有深入研究您的算法,但您的意思可能是 int c = NumH - 1
。
抱歉,不能保证它是唯一的。
关于c++ - C++中的指针内存分配,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9591908/
我有一个应用程序,它会抛出 GKSession 并在各种条件下(连接超时、 session 失败等)创建一个新的 GKSession。不过,我遇到了内存泄漏问题,并且有时会在重新连接几次循环后崩溃。
比如我在宿主代码中有一个浮点指针 float *p 是否可以确定他指向的内存类型(设备/主机)? 最佳答案 在 UVA system 中, 运行时 API 函数 cudaPointerGetAttri
我已将项目转换为 .Net 4.0 并且以下代码不起作用: typeof(RuntimeTypeHandle).GetMethod("Allocate", BindingFlags.Instance
当我声明 char ch = 'ab' 时,ch 只包含 'b',为什么它不存储 'a'? #include int main() { char ch = 'ab'; printf("%c"
我对 Disk Sector 和 Block 有疑问。扇区是一个单位,通常为 512 字节或 1k、2k、4k 等取决于硬件。文件系统 block 大小是一组扇区大小。 假设我正在存储一个 5KB 的
假设我有 8 个人和5000 个苹果。 我想将所有苹果分发给所有 8 个人,这样我就没有苹果了。 但每个人都应该得到不同数量 将它们全部分发出去的最佳方式是什么? 我是这样开始的: let peopl
我正在构建的网站顶部有一个搜索栏。与 Trello 或 Gmail 类似,我希望当用户按下“/”键时,他们的焦点就会转到该搜索框。 我的 JavaScript 看起来像这样: document.onk
我有一小段代码: if (PZ_APP.dom.isAnyDomElement($textInputs)){ $textInputs.on("focus", function(){
我观察到以下行为。 接受了两个属性变量。 @property (nonatomic, retain) NSString *stringOne; @property (nonatomic, assign
我正在解决这样的问题 - 实现一个计算由以下内容组成的表达式的函数以下操作数:“(”、“)”、“+”、“-”、“*”、“/”。中的每个数字表达式可能很大(与由字符串表示的一样大)1000 位)。 “/
我有一组主机和一组任务。 每个主机都有 cpu、mem 和任务容量,每个任务都有 cpu、mem 要求。 每个主机都属于一个延迟类别,并且可以与具有特定延迟值的其他主机通信。 每个任务可能需要以等于或
该程序的作用:从文件中读取一个包含 nrRows 行和 nrColomns 列的矩阵(二维数组)。矩阵的所有元素都是 [0,100) 之间的整数。程序必须重新排列矩阵内的所有元素,使每个元素等于其所在
世界!我有个问题。今天我尝试创建一个代码,它可以找到加泰罗尼亚语号码。但是在我的程序中可以是长数字。我找到了分子和分母。但我不能分割长数字!此外,只有标准库必须在此程序中使用。请帮帮我。这是我的代码
我确定我遗漏了一些明显的东西,但我想在 Objective C 中创建一个 NSInteger 指针的实例。 -(NSInteger*) getIntegerPointer{ NSInteger
这个问题在这里已经有了答案: Difference between self.ivar and ivar? (4 个答案) 关闭 9 年前。
我如何将 v[i] 分配给一系列整数(v 的类型是 vector )而无需最初填充 最佳答案 你的意思是将 std::vector 初始化为一系列整数? int i[] = {1, 2, 3, 4,
我想寻求分配方面的帮助....我把这个作业带到了学校......我必须编写程序来加载一个 G 矩阵和第二个 G 矩阵,并搜索第二个 G 矩阵以获取存在数第一个 G 矩阵的......但是,当我尝试运行
我必须管理资源。它基本上是一个唯一的编号,用于标识交换机中的第 2 层连接。可以有 16k 个这样的连接,因此每次用户希望配置连接时,他/她都需要分配一个唯一索引。同样,当用户希望删除连接时,资源(号
是否有任何通用的命名约定来区分已分配和未分配的字符串?我正在寻找的是希望类似于 us/s 来自 Making Wrong Code Look Wrong ,但我宁愿使用常见的东西也不愿自己动手。 最佳
我需要读取一个 .txt 文件并将文件中的每个单词分配到一个结构中,该结构从结构 vector 指向。我将在下面更好地解释。 感谢您的帮助。 我的程序只分配文件的第一个字... 我知道问题出在函数 i
我是一名优秀的程序员,十分优秀!