diff --git a/.github/workflows/dotnetcore.yml b/.github/workflows/dotnetcore.yml new file mode 100644 index 0000000..22cc4eb --- /dev/null +++ b/.github/workflows/dotnetcore.yml @@ -0,0 +1,23 @@ +name: .NET Core + +on: [push, pull_request] + +jobs: + build: + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v1 + - name: Setup .NET Core + uses: actions/setup-dotnet@v1 + with: + dotnet-version: 2.1.802 + - name: Build with dotnet + run: | + cd CourseApp + dotnet build --configuration Release + - name: Run tests + run: | + cd CourseApp.Tests + dotnet test diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..24cb440 --- /dev/null +++ b/.gitignore @@ -0,0 +1,205 @@ +# Download this file using PowerShell v3 under Windows with the following comand: +# Invoke-WebRequest https://gist.githubusercontent.com/kmorcinek/2710267/raw/ -OutFile .gitignore +# or wget: +# wget --no-check-certificate http://gist.githubusercontent.com/kmorcinek/2710267/raw/.gitignore + +# User-specific files +*.suo +*.user +*.sln.docstates + +# Build results + +[Dd]ebug/ +[Rr]elease/ +x64/ +build/ +[Bb]in/ +[Oo]bj/ + +# NuGet Packages +*.nupkg +# The packages folder can be ignored because of Package Restore +**/packages/* +# except build/, which is used as an MSBuild target. +!**/packages/build/ +# Uncomment if necessary however generally it will be regenerated when needed +#!**/packages/repositories.config + +# MSTest test Results +[Tt]est[Rr]esult*/ +[Bb]uild[Ll]og.* + +*_i.c +*_p.c +*.ilk +*.meta +*.obj +*.pch +*.pdb +*.pgc +*.pgd +*.rsp +*.sbr +*.tlb +*.tli +*.tlh +*.tmp +*.tmp_proj +*.log +*.vspscc +*.vssscc +.builds +*.pidb +*.log +*.scc + +# OS generated files # +.DS_Store* +Icon? + +# Visual C++ cache files +ipch/ +*.aps +*.ncb +*.opensdf +*.sdf +*.cachefile + +# Visual Studio profiler +*.psess +*.vsp +*.vspx + +# Guidance Automation Toolkit +*.gpState + +# ReSharper is a .NET coding add-in +_ReSharper*/ +*.[Rr]e[Ss]harper + +# TeamCity is a build add-in +_TeamCity* + +# DotCover is a Code Coverage Tool +*.dotCover + +# NCrunch +*.ncrunch* +.*crunch*.local.xml + +# Installshield output folder +[Ee]xpress/ + +# DocProject is a documentation generator add-in +DocProject/buildhelp/ +DocProject/Help/*.HxT +DocProject/Help/*.HxC +DocProject/Help/*.hhc +DocProject/Help/*.hhk +DocProject/Help/*.hhp +DocProject/Help/Html2 +DocProject/Help/html + +# Click-Once directory +publish/ + +# Publish Web Output +*.Publish.xml + +# Windows Azure Build Output +csx +*.build.csdef + +# Windows Store app package directory +AppPackages/ + +# Others +*.Cache +ClientBin/ +# [Ss]tyle[Cc]op.* +~$* +*~ +*.dbmdl +*.[Pp]ublish.xml +*.pfx +*.publishsettings +modulesbin/ +tempbin/ + +# EPiServer Site file (VPP) +AppData/ + +# RIA/Silverlight projects +Generated_Code/ + +# Backup & report files from converting an old project file to a newer +# Visual Studio version. Backup files are not needed, because we have git ;-) +_UpgradeReport_Files/ +Backup*/ +UpgradeLog*.XML +UpgradeLog*.htm + +# vim +*.txt~ +*.swp +*.swo + +# svn +.svn + +# Remainings from resolvings conflicts in Source Control +*.orig + +# SQL Server files +**/App_Data/*.mdf +**/App_Data/*.ldf +**/App_Data/*.sdf + + +#LightSwitch generated files +GeneratedArtifacts/ +_Pvt_Extensions/ +ModelManifest.xml + +# ========================= +# Windows detritus +# ========================= + +# Windows image file caches +Thumbs.db +ehthumbs.db + +# Folder config file +Desktop.ini + +# Recycle Bin used on file shares +$RECYCLE.BIN/ + +# Mac desktop service store files +.DS_Store + +# SASS Compiler cache +.sass-cache + +# Visual Studio 2014 CTP +**/*.sln.ide + +# Visual Studio temp something +.vs/ + +# VS 2015+ +*.vc.vc.opendb +*.vc.db + +# Rider +.idea/ + +**/node_modules/* + +# Added by Jskonst +Properties/ + +##### +# End of core ignore list, below put you custom 'per project' settings (patterns or path) +##### \ No newline at end of file diff --git a/ConsoleApp.Tests/ConsoleApp.Tests.csproj b/ConsoleApp.Tests/ConsoleApp.Tests.csproj new file mode 100644 index 0000000..24bc394 --- /dev/null +++ b/ConsoleApp.Tests/ConsoleApp.Tests.csproj @@ -0,0 +1,20 @@ + + + + netcoreapp2.0 + + false + + + + + + + + + + + + + + diff --git a/ConsoleApp.Tests/UnitTest.cs b/ConsoleApp.Tests/UnitTest.cs new file mode 100644 index 0000000..2441179 --- /dev/null +++ b/ConsoleApp.Tests/UnitTest.cs @@ -0,0 +1,48 @@ +using Microsoft.VisualStudio.TestPlatform.TestHost; +using System; +using System.Collections.Generic; +using Xunit; + +namespace exApp.XUnitTests +{ + public class UnitTest1 + { + [Fact] + public void BasicWork() + { + List a = new List() { 1, 4, -11, -5, 55, -55 }; + List list = Program.GetZeroSumms(a); + if ((list[0] == new int[2] { -50,50}) && (list[1] == new int[2] { -7,7 })) + { + Assert.True(true); + } + } + + [Fact] + public void NoResult() + { + List a = new List() { 1, 4, -11, -55 }; + List list = Program.GetZeroSumms(a); + Assert.Equal(new List(), list); + } + + [Fact] + public void EmptyInput() + { + List a = new List(); + List list = Program.GetZeroSumms(a); + Assert.Equal(new List(), list); + } + + [Fact] + public void MultipleEqualNumbers() + { + List a = new List() { 1, 4, -11, -5, 55, -55, 5, -55 }; + List list = Program.GetZeroSumms(a); + if ((list[0] == new int[2] { -50, 50 }) && (list[1] == new int[2] { -7, 7 }) && list.Count == 2) + { + Assert.True(true); + } + } + } +} diff --git a/ConsoleApp/ConsoleApp.csproj b/ConsoleApp/ConsoleApp.csproj new file mode 100644 index 0000000..cf32e1e --- /dev/null +++ b/ConsoleApp/ConsoleApp.csproj @@ -0,0 +1,13 @@ + + + + Exe + netcoreapp2.1 + 7.2 + + + + + + + diff --git a/ConsoleApp/Program.cs b/ConsoleApp/Program.cs new file mode 100644 index 0000000..b13ccb4 --- /dev/null +++ b/ConsoleApp/Program.cs @@ -0,0 +1,44 @@ +using System; +using System.Collections.Generic; + +namespace exApp +{ + public class Program + { + static void Main(string[] args) + { + Console.WriteLine("Hello World!"); + } + public static List GetZeroSumms(List list) + { + List vvod = list; + vvod.Sort(); + List result = new List(); + int f = 0; + int j = vvod.Count - 1; + while (j > f) + { + if (vvod[f] == 0 - vvod[j]) + { + result.Add(new int[2] { vvod[f], vvod[j] }); + f++; + } + else + { + if (Math.Abs(vvod[j]) > Math.Abs(vvod[f])) + { + j--; + } + else + { + f++; + } + } + + } + + return result; + } + } + +} diff --git a/README.md b/README.md index f097ac3..6927964 100644 --- a/README.md +++ b/README.md @@ -1 +1 @@ -# exam_147_2020 \ No newline at end of file +# Валерия Киселёва \ No newline at end of file diff --git a/_stylecop/stylecop.json b/_stylecop/stylecop.json new file mode 100644 index 0000000..4a96e8f --- /dev/null +++ b/_stylecop/stylecop.json @@ -0,0 +1,12 @@ +{ + "$schema": "https://raw.githubusercontent.com/DotNetAnalyzers/StyleCopAnalyzers/master/StyleCop.Analyzers/StyleCop.Analyzers/Settings/stylecop.schema.json", + "settings": { + "documentationRules": { + "documentExposedElements": false, + "documentInterfaces": false, + "companyName": "Test Company", + "copyrightText": "This source code is Copyright © {companyName} and MAY NOT be copied, reproduced,\npublished, distributed or transmitted to or stored in any manner without prior\nwritten consent from {companyName} (www.yourcompany.com).", + "xmlHeader":false + } + } +} \ No newline at end of file diff --git a/_stylecop/stylecop.ruleset b/_stylecop/stylecop.ruleset new file mode 100644 index 0000000..98806c8 --- /dev/null +++ b/_stylecop/stylecop.ruleset @@ -0,0 +1,14 @@ + + + + + + + + + + + + + + \ No newline at end of file diff --git a/courseworkspace.code-workspace b/courseworkspace.code-workspace new file mode 100644 index 0000000..b3042c3 --- /dev/null +++ b/courseworkspace.code-workspace @@ -0,0 +1,11 @@ +{ + "folders": [ + { + "path": "ConsoleApp" + }, + { + "path": "ConsoleApp.Tests" + } + ], + "settings": {} +} \ No newline at end of file