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