- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有2个文件,一个是.cpp,另一个是标头。
这是.cpp文件
#include "exercises.h"
using namespace std;
/* Tema 1 */
/* Exercitiul 1
Scrieti o functie care sa calculeze suma cifrelor unui numar natural.
*/
unsigned int computeDigitSum(unsigned int number)
{
int sum = 0;
while (number)
{
sum = sum + number % 10;
number = number / 10;
}
return sum;
}
/* Exercitiul 2
Scrieti o functie care verifica daca un an este bisect.
*/
bool isLeap(unsigned int year)
{
if (year % 4 == 0 && year % 100 != 0) return true;
else if (year % 400 == 0) return true;
return false;
}
/* Exercitiul 3
Scrieti o functie care sa testeze daca un numar este palindrom.
Un numar este palindrom daca citit de la dreapta la stanga este egal cu numarul citit de la stanga la dreapta.
Exemple: 36463 este palindrom, dar 2646 nu este palindrom.
*/
bool isPalindrome(int number)
{
int aux = number, invertedNumber = 0;
while (number > 0)
{
invertedNumber = invertedNumber * 10 + number % 10;
number = number / 10;
}
if (aux == invertedNumber) return true;
return false;
}
/* Exercitiul 4
Scrieti un program, care, pentru o luna si un an date, calculeaza numarul de zile din luna respectiva
(folositi o functie separata care verifica daca un an este bisect).
Exemplu: pentru luna februarie din anul 2004, numarul de zile este 29.
*/
unsigned int computeNumberOfDays(unsigned int year, unsigned int month)
{
if (month == 0 || month > 12)
return 0;
if (month == 2)
{
if (isLeap(year)) return 29;
else return 28;
}
else if (month == 4 || month == 6 || month == 9 || month == 11) return 30;
else return 31;
}
/* Exercitiul 5
Scrieti o functie care calculeaza cifra de control a unui numar natural.
Cifra de control se obtine calculand suma cifrelor numarului,
apoi suma cifrelor numarului obtinut etc., pana se ajunge la o singura cifra.
Exemplu: 4879 -> 28 -> 10 -> 1.
*/
unsigned int computeControlDigit(unsigned int number)
{
while (number > 9)
{
number = computeDigitSum(number);
}
return number;
}
/* Exercitiul 6
Spunem ca un numar natural este perfect daca este egal cu suma divizorilor sai strict mai mici decat el.
Scrieti o functie care verifica daca un numar este perfect.
Exemplu: 28 este un numar perfect deoarece 28 = 1 + 2 + 4 + 7 + 14.
Sa se determine toate numerele perfecte mai mici ca un numar natural n dat.
Exemplu: pentru n = 1000, se vor determina numerele 6, 28, 496.
*/
bool isPerfect(unsigned int number)
{
int sum = 0, i;
if (number == 0) return false;
for (i = 1; i <= number/2; i++)
{
if (number % i == 0)
sum = sum + i;
}
if (sum == number) return true;
return false;
}
vector getPerfects(unsigned int upperLimit)
{
vector v;
v.length = 0;
int i;
for (i = 1; i < upperLimit; i++)
{
if (isPerfect(i))
{
v.values[v.length] = i;
v.length++;
}
}
return v;
}
/* Exercitiul 7
Sa se testeze daca un numar este prim.
Exemple: 1000003 este prim, dar 1000002 este compus deoarece este divizibil prin 3.
*/
bool isPrime(int number)
{
int i;
if (number < 0)
number = abs(number);
for (i = 2; i <= number/2; i++)
if (number % i == 0)
return false;
if (number < 2)
return false;
return true;
}
/* Exercitiul 8
Doua numere naturale impare consecutive si prime se numesc numere prime gemene.
Folosind testul de primalitate implementat anterior, determinati primele n perechi de numere prime gemene.
Exemplu: Primele n = 3 perechi de numere prime gemene sunt (3, 5), (5, 7) si (11, 13).
*/
bool areTwinPrimes(unsigned int number1, unsigned int number2)
{
if (isPrime(number1) && isPrime(number2) && number2 - number1 == 2)
return true;
return false;
}
matrix getTwinPrimes(unsigned int count)
{
matrix m;
m.columns = 2;
m.lines = 0;
int i;
for (i = 3; i < count - 2; i++)
if (areTwinPrimes(i, i + 2))
{
m.values[m.lines][0] = i;
m.values[m.lines][1] = i + 2;
m.lines++;
}
return m;
}
/* Exercitiul 9
Se citeste un tablou de numere intregi.
Scrieti o functie care determina diferenta maxima (in modul) dintre oricare doua elemente ale vectorului.
Exemplu: pentru tabloul (1, 3, 2, 7, 11, 3, 2), diferenta maxima (in modul) este 12.
*/
unsigned int getMaxDifference(vector v)
{
int i, j, maxDifference = 0, difference;
for (i = 0; i < v.length - 1; i++)
for (j = i + 1; j < v.length; j++)
{
difference = v.values[i] - v.values[j];
difference = abs(difference);
if (difference > maxDifference)
maxDifference = difference;
}
return maxDifference;
}
/* Exercitiul 10
Se citeste un tablou de numere intregi.
Sa se determine, printr-o singura parcurgere a sa, pozitia de inceput si lungimea celei mai lungi secvente de elemente egale.
Daca exista mai multe secvente de lungimi egale, se va determina secventa cu pozitia de inceput minima.
Exemplu: pentru tabloul (1, 2, 3, 3, 3, 2, 1, 5, 5, 5), se vor determina pozitia 2 si lungimea 3.
*/
sequence getMaxSequence(vector v)
{
sequence maxSumSequence;
maxSumSequence.startPosition = 1;
maxSumSequence.length = 1;
int i, j, maxSum = v[0], sum = v[0];
for (i = 0; i < v.length - 1; i++)
{
sum = v.values[i];
for (j = i + 1; j < v.length; j++)
{
sum = sum + v.values[j];
if (sum > maxSum)
{
maxSum = sum;
maxSumSequence.startPosition = i;
maxSumSequence.length = j - i + 1;
}
}
}
return maxSumSequence;
}
/* Exercitiul 11
Se da un vector de numere intregi.
Sa se determine subsecventa pentru care suma elementelor componente este maxima.
Daca exista mai multe subsecvente cu aceasta proprietate, se va determina ultima subsecventa gasita.
Exemplu: pentru tabloul (2, 3, 4, 2, 9, 2, 1, 7, 3), subsecventa este (9, 2, 1, 7).
*/
sequence getMaxSumSequence(vector v)
{
sequence maxSumSequence;
maxSumSequence.startPosition = 0;
maxSumSequence.length = 1;
int i, j, maxSum = 0, sum;
for (i = 0; i < v.length - 1; i++)
{
sum = v.values[i];
for (j = i + 1; j < v.length; j++)
{
sum = sum + v.values[j];
if (sum > maxSum)
{
maxSum = sum;
maxSumSequence.startPosition = i;
maxSumSequence.length = j - i + 1;
}
}
}
return maxSumSequence;
}
/* Exercitiul 12
Se citeste un tablou de numere intregi.
Sa se rearanjeze elementele astfel incat cele pare sa apara inaintea celor impare.
In cadrul subsecventei de numere pare, respectiv impare, elementele trebuie sa apara in ordinea in care erau in tabloul initial.
Exemplu: tabloul (2, 3, 4, 2, 9, 2, 1, 7, 3) va fi rearanjat in (2, 4, 2, 2, 3, 9, 1, 7, 3).
*/
vector orderElements(vector v)
{
int vectorAuxiliar[100], i, position = 0;
for (i = 0; i < v.length; i++)
vectorAuxiliar[i] = v.values[i];
for (i = 0; i < v.length; i++)
if (vectorAuxiliar[i] % 2 == 0)
{
v.values[position] = vectorAuxiliar[i];
position++;
}
for (i = 0; i < v.length; i++)
if (vectorAuxiliar[i] % 2 != 0)
{
v.values[position] = vectorAuxiliar[i];
position++;
}
return v;
}
/* Exercitiul 13
Se considera un tablou cu n elemente.
Sa se decida daca exista un element majoritar (cu numarul de aparitii mai mare decat n/2).
*/
bool containsMajorElement(vector v)
{
int i, j, elementCount;
for (i = 0; i < v.length; i++)
{
elementCount = 0;
for (j = 0; j < v.length; j++)
if (v.values[i] == v.values[j])
elementCount++;
if (elementCount > v.length / 2) return true;
}
return false;
}
/* Exercitiul 14
Se considera o matrice patratica cu n elemente.
Sa se interschimbe liniile si coloanele acesteia astfel incat, in matricea finala, elementele de pe diagonala principala sa fie in ordine descrescatoare.
Sa se afiseze matricea initiala si matricea dupa fiecare operatie.
*/
matrix sortDiagonalElements(matrix m)
{
int i, j, x, z, aux;
for (i = 0; i < m.lines - 1; i++)
for (j = i + 1; j < m.lines; j++)
if (m.values[i][i] < m.values[j][j])
{
for (x = 0; x < m.lines; x++)
{
aux = m.values[x][j];
m.values[x][j] = m.values[x][i];
m.values[x][i] = aux;
}
for (x = 0; x < m.columns; x++)
{
aux = m.values[j][x];
m.values[j][x] = m.values[i][x];
m.values[i][x] = aux;
}
}
return m;
}
/* Exercitiul 15
Scrieti o functie care citeste elementele unei matrici patratice de dimensiune n.
Afisati sirul format prin parcurgerea acesteia in spirala, pornind din coltul stanga sus catre dreapta pana in centrul matricei.
*/
vector getSpiralVector(matrix m)
{
vector v;
v.length = 0;
int top = 0, down = m.lines, left = 0, right = m.columns, i, j;
bool OK = true;
while (OK)
{
for (j = left; j < right; j++)
{
v.values[v.length] = m.values[top][j];
v.length++;
}
top++;
if (top > down || left > right) OK = false;
for (i = top; i < down; i++)
{
v.values[v.length] = m.values[i][right - 1];
v.length++;
}
right--;
if (top > down || left > right) OK = false;
for (j = right - 1; j >= left; j--)
{
v.values[v.length] = m.values[down - 1][j];
v.length++;
}
down--;
if (top > down || left > right) OK = false;
for (i = down - 1; i >= top; i--)
{
v.values[v.length] = m.values[i][left];
v.length++;
}
left++;
if (top > down || left > right) OK = false;
}
return v;
}
/* Exercitiul 16
Sa se defineasca un tip pentru reprezentarea datelor calendaristice.
Sa se scrie o functie care primeste la intrare o data calendaristica si returneaza succesorul acesteia.
Exemplu: succesorul datei "31.10.2014" este "1.11.2014".
*/
date getNextDate(date currentDate)
{
if (currentDate.day == 31 && currentDate.month == 12) {
currentDate.day = 1;
currentDate.month = 1;
currentDate.year = currentDate.year + 1;
}
else if (currentDate.day < computeNumberOfDays(currentDate.year, currentDate.month))
{
currentDate.day = currentDate.day + 1;
}
else if (currentDate.day == computeNumberOfDays(currentDate.year, currentDate.month))
{
currentDate.day = 1;
currentDate.month = currentDate.month + 1;
}
return currentDate;
}
/* Exercitiul 17
Sa se determine ecuatia unei drepte care trece prin doua puncte in plan.
Exemplu: pentru punctele (2, 1) si (5, 7), ecuatia dreptei este 2x â y â 3 = 0.
Precizia pentru a, b si c va fi de 2 zecimale.
Ecuatia va fi redusa.
*/
equation computeEquation(point point1, point point2)
{
equation dreapta;
dreapta.a = point2.y - point1.y;
dreapta.b = (-1)*(point2.x - point1.x);
dreapta.c = point1.y * point2.x - point1.x * point2.y;
return dreapta;
}
#include <iostream>
#include <cmath>
using namespace std;
#define MAX_ARRAY_LENGTH 100
struct vector
{
unsigned int length;
int values[MAX_ARRAY_LENGTH];
};
struct matrix
{
unsigned int lines;
unsigned int columns;
int values[MAX_ARRAY_LENGTH][MAX_ARRAY_LENGTH];
};
struct sequence
{
unsigned int startPosition;
unsigned int length;
};
struct point
{
double x;
double y;
};
struct equation
{
double a;
double b;
double c;
};
struct date
{
unsigned int year;
unsigned int month;
unsigned int day;
};
/* Tema 1 */
/* Exercitiul 1
Scrieti o functie care sa calculeze suma cifrelor unui numar natural.
*/
unsigned int computeDigitSum(unsigned int number);
/* Exercitiul 2
Scrieti o functie care verifica daca un an este bisect.
*/
bool isLeap(unsigned int year);
/* Exercitiul 3
Scrieti o functie care sa testeze daca un numar este palindrom.
Un numar este palindrom daca citit de la dreapta la stanga este egal cu numarul citit de la stanga la dreapta.
Exemple: 36463 este palindrom, dar 2646 nu este palindrom.
*/
bool isPalindrome(int number);
/* Exercitiul 4
Scrieti un program, care, pentru o luna si un an date, calculeaza numarul de zile din luna respectiva
(folositi o functie separata care verifica daca un an este bisect).
Exemplu: pentru luna februarie din anul 2004, numarul de zile este 29.
*/
unsigned int computeNumberOfDays(unsigned int year, unsigned int month);
/* Exercitiul 5
Scrieti o functie care calculeaza cifra de control a unui numar natural.
Cifra de control se obtine calculand suma cifrelor numarului,
apoi suma cifrelor numarului obtinut etc., pana se ajunge la o singura cifra.
Exemplu: 4879 -> 28 -> 10 -> 1.
*/
unsigned int computeControlDigit(unsigned int number);
/* Exercitiul 6
Spunem ca un numar natural este perfect daca este egal cu suma divizorilor sai strict mai mici decat el.
Scrieti o functie care verifica daca un numar este perfect.
Exemplu: 28 este un numar perfect deoarece 28 = 1 + 2 + 4 + 7 + 14.
Sa se determine toate numerele perfecte mai mici ca un numar natural n dat.
Exemplu: pentru n = 1000, se vor determina numerele 6, 28, 496.
*/
bool isPerfect(unsigned int number);
vector getPerfects(unsigned int upperLimit);
/* Exercitiul 7
Sa se testeze daca un numar este prim.
Exemple: 1000003 este prim, dar 1000002 este compus deoarece este divizibil prin 3.
*/
bool isPrime(int number);
/* Exercitiul 8
Doua numere naturale impare consecutive si prime se numesc numere prime gemene.
Folosind testul de primalitate implementat anterior, determinati primele n perechi de numere prime gemene.
Exemplu: Primele n = 3 perechi de numere prime gemene sunt (3, 5), (5, 7) si (11, 13).
*/
bool areTwinPrimes(unsigned int number1, unsigned int number2);
matrix getTwinPrimes(unsigned int count);
/* Exercitiul 9
Se citeste un tablou de numere intregi.
Scrieti o functie care determina diferenta maxima (in modul) dintre oricare doua elemente ale vectorului.
Exemplu: pentru tabloul (1, 3, 2, 7, 11, 3, 2), diferenta maxima (in modul) este 12.
*/
unsigned int getMaxDifference(vector v);
/* Exercitiul 10
Se citeste un tablou de numere intregi.
Sa se determine, printr-o singura parcurgere a sa, pozitia de inceput si lungimea celei mai lungi secvente de elemente egale.
Daca exista mai multe secvente de lungimi egale, se va determina secventa cu pozitia de inceput minima.
Exemplu: pentru tabloul (1, 2, 3, 3, 3, 2, 1, 5, 5, 5), se vor determina pozitia 2 si lungimea 3.
*/
sequence getMaxSequence(vector v);
/* Exercitiul 11
Se da un vector de numere intregi.
Sa se determine subsecventa pentru care suma elementelor componente este maxima.
Daca exista mai multe subsecvente cu aceasta proprietate, se va determina ultima subsecventa gasita.
Exemplu: pentru tabloul (2, 3, 4, 2, 9, 2, 1, 7, 3), subsecventa este (9, 2, 1, 7).
*/
sequence getMaxSumSequence(vector v);
/* Exercitiul 12
Se citeste un tablou de numere intregi.
Sa se rearanjeze elementele astfel incat cele pare sa apara inaintea celor impare.
In cadrul subsecventei de numere pare, respectiv impare, elementele trebuie sa apara in ordinea in care erau in tabloul initial.
Exemplu: tabloul (2, 3, 4, 2, 9, 2, 1, 7, 3) va fi rearanjat in (2, 4, 2, 2, 3, 9, 1, 7, 3).
*/
vector orderElements(vector v);
/* Exercitiul 13
Se considera un tablou cu n elemente.
Sa se decida daca exista un element majoritar (cu numarul de aparitii mai mare decat n/2).
*/
bool containsMajorElement(vector v);
/* Exercitiul 14
Se considera o matrice patratica cu n elemente.
Sa se interschimbe liniile si coloanele acesteia astfel incat, in matricea finala, elementele de pe diagonala principala sa fie in ordine descrescatoare.
Sa se afiseze matricea initiala si matricea dupa fiecare operatie.
*/
matrix sortDiagonalElements(matrix m);
/* Exercitiul 15
Scrieti o functie care citeste elementele unei matrici patratice de dimensiune n.
Afisati sirul format prin parcurgerea acesteia in spirala, pornind din coltul stanga sus catre dreapta pana in centrul matricei.
*/
vector getSpiralVector(matrix m);
/* Exercitiul 16
Sa se defineasca un tip pentru reprezentarea datelor calendaristice.
Sa se scrie o functie care primeste la intrare o data calendaristica si returneaza succesorul acesteia.
Exemplu: succesorul datei "31.10.2014" este "1.11.2014".
*/
date getNextDate(date currentDate);
/* Exercitiul 17
Sa se determine ecuatia unei drepte care trece prin doua puncte in plan.
Exemplu: pentru punctele (2, 1) si (5, 7), ecuatia dreptei este 2x – y – 3 = 0.
Precizia pentru a, b si c va fi de 2 zecimale.
Ecuatia va fi redusa.
*/
equation computeEquation(point point1, point point2);
最佳答案
如Paul R所说,检查头文件在项目中。
另一方面,使用“ vector”作为结构的名称可能不是一个好主意,而且我通常不添加“ using namespace std;”。在头文件中,包括头文件的任何人都可以看到std名称空间,无论是否需要它。在您的情况下,这还会使CPP文件中的using名称空间行变得多余。
关于c++ - 错误1错误C1083:无法打开包含文件:'exercises.h':没有此类文件或目录,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26801194/
我正在为我的程序编写安装脚本,它应该在 Linux/Unix 操作系统上运行。以下文件的默认目录是什么: 可执行文件(程序)。程序应通过从命令行键入其名称来执行。 共享库。 第三方共享库(程序未开源,
我有一堆用户、组和应用程序注册,我的 MVC 应用程序使用 AAD 数据进行身份验证和授权。是否可以将 Azure Active Directory 从一个租户(目录)迁移到另一个租户(目录)?如果可
查看 cljsbuild 文档 https://github.com/emezeske/lein-cljsbuild :cljsbuild { :builds [{ ; The
忽略已经版本控制的文件 如果你不小心添加了一些应该被忽略的文件,你如何将它们从版本控制中去除而不会丢失它们?或许你有自己的IDE配置文件,不是项目的一部分,但将会花费很多时间使之按照自己的方式工作。
我想使用\tableofcontents 命令,但没有目录从新页面开始或在末尾创建新页面,并且所有内容都是单倍行距。我怎样才能做到这一点?我假设使用 tocloft,但有哪些选择? 谢谢 最佳答案 试
我有一些 javascript 菜单代码,可以在单独的目录中正常工作。但是,当我尝试从同一目录中调用相同的 .js 文件时,它不会看到这些文件。 以下内容来自另一个目录: script type="t
我有这样的路径: /my/path/to/important_folder 在同一级别上,我还有其他文件和文件夹想要在达到与 important_folder 相同的级别时列出。 我的文件夹可能更深,
1、获取文件路径实现 1.1 获取当前文件路径 ? 1
我正在使用最新版本的 NTEmacs。 我写了一个名为“.dir-locals.el”的文件,如下所示。 ((nil . ((tab-width . 8) (fill-column .
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 7年前关闭。 Improve thi
在我的 .vimrc 中有这些行 :set foldmethod=marker :set foldmarker=SECTION:,ENDSECTION: 用于自定义代码折叠。在我的文件中,相关语言的注
在 fish 中: for x in * echo $x end *这里包括所有目录和文件,如何只列出文件(或目录)? 最佳答案 fish 没有很多花哨的通配语法。但是,目录可以像这样迭代: f
这是我的目录结构: ├── src │ ├── helpers │ │ ├── __init__.py │ │ ├── foo.py │ │ └── bar.py │
我想递归重命名文件夹/目录名称并找到 this solution所以。但是这个命令没有效果 find . -type f -exec rename 's/old/new/' '{}' \; 这是一个正
我想在相册中创建一个文件夹,并希望将图像保存在创建的相册中。 这可能吗?有什么办法可以做到这一点吗? 我已经搜索过,大多数人都说这是不可能的。 感谢您的帮助。 最佳答案 您也许可以使用AssetsLi
如何在python中使用用户定义的名称创建临时文件/目录。我知道 tempfile .但是我看不到任何以文件名作为参数的函数。 注意:我需要这个来对包含临时文件的临时目录上的 glob(文件名模式匹配
我在项目中使用JaCoCo Gradle插件。 作为问题的一个示例,我的大部分代码都在com.me.mysoftware包下。 我正在使用代码生成器来生成build/generated/java/..
我正在尝试使用 Gradle 开始运行 jar 文件 我的任务如下所示: task startServer(type: Exec) { workingDir file("${buildDir}/a
如何在 Ant 中定义一个目录集,其中包括两个目录:项目的基目录和子目录“test”? 看起来您无法使用“/”、“.”或“”专门包含目录集的根目录。例如,这包括“./test”,但不包括“.”:
我正在使用 CTAGs 包,它使用 Sublime Text 2 生成两个文件 .tags 和 .tags_sorted_by_file。 那么当我进行项目搜索(CMD + SHIFT + F)时,如
我是一名优秀的程序员,十分优秀!